Struts+Hibernate+MySql

 
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)
如有问题发生,欢迎批评指教!
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值