我正在使用 Hibernate 通过 Struts 2 开发一个 Web 应用程序。
但是我有一个问题,当我启动服务器并加载网站时,我的加载方法将被调用。但是,它无法加载 UTF-8,而不是"Phương"
我得到"PH??NG"
But in JSP page still display "Phương"
。因此,当我执行我的 SQL 查询时,它是 ( from Posts WHERE topics like '%PH??NG PHÁP GIÁO D?C TR?%'
,所以我无法查询我的数据库。
我的动作课在这里:
public class PostsAction extends ActionSupport {
private List<HomeTopic> homeTopics = new ArrayList<HomeTopic>();
public List<HomeTopic> getHomeTopics() {
return homeTopics;
}
public void setHomeTopics(List<HomeTopic> homeTopics) {
this.homeTopics = homeTopics;
}
public void callHomeTopics(){
Session session = HibernateUtil.getSessionFactory().openSession();
Transaction trans = session.beginTransaction();
String[] list = {"NEW – TIN TỨC TRẺ","Khu Vui Chơi Cho Trẻ","PHƯƠNG PHÁP GIÁO DỤC TRẺ","KỸ NĂNG – KINH NGHIỆM","Phòng Bệnh","Tập Tô Màu"};
for (int i = 0; i < list.length; i++) {
getTopics(session, trans, list[i]);
}
trans.commit();
session.close();
}
public void getTopics(Session session, Transaction trans, String type) {
String hql = "from Posts WHERE topics like '%" + type + "%'";
System.out.println("HQL: " + hql);
Query query = session.createQuery(hql);
query.setMaxResults(3);
List<Posts> t = (ArrayList<Posts>) query.list();
HomeTopic h = new HomeTopic(type, t);
System.out.println("List topics: " + type + " " + t);
homeTopics.add(h);
session.flush();
}
HomeTopics.java
班级:
public class HomeTopic {
private String nameTopic;
private List<Posts> postList;
public List<Posts> getPostList() {
return postList;
}
public void setPostList(List<Posts> postList) {
this.postList = postList;
}
public HomeTopic(String nameTopic, List<Posts> postList) {
this.nameTopic = nameTopic;
this.postList = postList;
}
public HomeTopic() {
}
@Override
public String toString() {
return "HomeTopic{" + "nameTopic=" + nameTopic + ", postList=" + postList + '}';
}
public String getNameTopic() {
return nameTopic;
}
public void setNameTopic(String nameTopic) {
this.nameTopic = nameTopic;
}
}
当我编写 main 方法进行测试时,它仍然显示 UTF-8。但是每当我callHomeTopics()
在浏览器中启动服务器并调用方法时,文本将是"PH??NG PHÁP GIÁO D?C TR?"
.
但是在 JSP 页面中仍然显示"Phương Pháp Giáo Dục Trẻ"
。一切都好,除了我的 HQL 查询。