Struts+Hibernate+MySql
来源:互联网 发布:剑灵读图慢怎么优化 编辑:程序博客网 时间:2024/06/15 10:08
Struts+Hibernate+MySql 中文乱码问题解决方案
项目:china
数据库版本:4.0.23
几个关键地点:
一、MySql数据库:配置my.ini文件,内容如下:
#This File was made using the WinMySQLAdmin 1.4 Tool
#2005-10-25 17:36:48
#Uncomment or Add only the keys that you know how works.
#Read the MySQL Manual for instructions
[mysqld]
basedir=D:/mysql
#bind-address=192.168.0.23
datadir=D:/mysql/data
default-character-set=gb2312
#language=D:/mysql/share/your language directory
#slow query log#=
#tmpdir#=
#port=3306
#set-variable=key_buffer=16M
[WinMySQLadmin]
Server=D:/mysql/bin/mysqld-nt.exe
user=root
password=root
红色标注处为MySql缺省字符集配置
二、Hibernate.cfg.xml配置文件
在JDBC的URL处写:
jdbc:mysql://localhost:3306/china?useUnicode=true&characterEncoding=gb2312
此处由于环境问题在我的机器上不写“?useUnicode=true&characterEncoding=gb2312”也可以通过,但是在其他同学机器上就会出现乱码,保守一点写上比较好。
三、struts.action.NameAction.java
package struts.action;
import java.io.UnsupportedEncodingException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import struts.form.NameForm;
import bo.NameFacade;
import po.Name;
/**
* MyEclipse Struts
* Creation date: 12-26-2005
*
* XDoclet definition:
* @struts:action path="/name" name="nameForm" input="/form/name.jsp" scope="request" validate="true"
*/
public class NameAction extends Action {
// --------------------------------------------------------- Instance Variables
// --------------------------------------------------------- Methods
/**
* Method execute
* @param mapping
* @param form
* @param request
* @param response
* @return ActionForward
*/
public ActionForward execute(
ActionMapping mapping,
ActionForm form,
HttpServletRequest request,
HttpServletResponse response) {
//response.setContentType("text/html;charset=UTF-8");
/*try {
request.setCharacterEncoding("gb2312");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}*/
NameForm nameForm = (NameForm) form;
String name = nameForm.getName();
if(name!=null)
try {
name = new String(name.getBytes("ISO-8859-1"),"gb2312");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("+++action+++"+name);
NameFacade nameFacade = new NameFacade();
Name namedb = new Name();
namedb.setName(name);
nameFacade.addUser(namedb);
// TODO Auto-generated method stub
return mapping.findForward("suc");
}
}
红色代码段为从用户表单所得到的数据并经过Form,其为“ISO-8859-1”编码,将其用getBytes方法转换成“gb2312”编码。
四、china.jsp
<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>My JSP 'china.jsp' starting page</title>
</head>
<body>
<form name="form1" method="post" action="/china/name.do">
<input type="text" name="name">
<input type="submit" name="Submit" value="提交">
</form>
<a href="/china/view.do">查看</a>
</body>
</html>
红色标注处统一为“gb2312”编码。
五、view.jsp 如上修改,另外struts.form.NameForm.java不需要任何修改。
备注:经测试,增加、查看两相操作没有发现中文乱码问题
数据库中的数据应为转码后的数据,转码前的数据有待进一步测试
最后说一下我理解的数据流向:
浏览器IE,JSP&HTML ——> Form ——> Action ——> BO ——> PO ——> DB
(ISO-8859-1) (ISO-8859-1) (ISO-8859-1——>gb2312) (gb2312) (gb2312) (gb2312)
如有问题发生,欢迎批评指教!
- Struts+Hibernate+MySql
- Spring+Struts+Hibernate+Mysql
- spring+hibernate+struts+mysql
- hibernate+struts+mysql乱码问题
- MyEclipse+Struts+Hibernate+Mysql…
- Struts+Hibernate+MyEclipse+Tomcat+MySQL的乱码
- struts+hibernate+MySql中文乱码解决方案
- Struts+Hibernate+MySql 中文乱码问题解决方案
- struts + hibernate + MySql 中文乱码 解决方案
- Struts+Hibernate+MySql中文乱码解决方案
- 解决struts+hibernate+mysql乱码问题
- MyEclipse+Struts+Hibernate+Mysql开发环境配置
- Struts+spring+Hibernate+Mysql--环境搭建
- MyEclipse+Struts+Hibernate+Mysql开发环境配置
- Struts+Hibernate
- 程序员必备-struts,jsf,tomcat,mysql,hibernate,php中文指南
- Eclipse+MyEclipse+Struts+Hibernate+MySql动画系列教程下载
- hibernate+struts+mysql有关utf8乱码问题的解决。
- 移植注意事项
- Sql server一些常见性能问题的总结
- 对一大表(百万级以上)建立索引时应当注意的事项及提高性能的手段
- 查询中的N条记录,然后,对这N条记录排序
- 执行带嵌入参数的sql——sp_executesql
- Struts+Hibernate+MySql
- 封装游标存储过程(Pr_execsql2)
- ITIL及其实施步骤
- oracle学习总结(一)
- 如何实现插入并更新数据
- oracle学习总结(二)
- 对减肥有副作用的蔬菜和水果
- SQL语法速成
- 初识数据仓库(DataWarehousing)-“掀起你的盖头来”