struts国际化+mysql中文乱码的问题

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

花了三个多小时解决的struts国际化+mysql中文乱码的问题

动力:都是这个很多字段数据表惹的祸,本来大概3个星期前就决定在代码里硬编码处理(那时折腾了前前后后近30小时),现在节约了很多时间哦。。。。爽。。。。。休息下,晚上继续

浏览器 默认以UTF-8发送请求

数据库 一般是ISO-8859-1 useUnicode=true&characterEncoding=GBK可以同一编码

tomcat编译jsp 是ISO-8859-1

做法:

jsp:<%@ page contentType="text/html;charset=UTF-8" language="java"%>

数据库:jdbc:mysql://127.0.0.1:3306/edusys?useUnicode=true&amp;characterEncoding=GBK

现象:

1.数据库里是中文也能显示成中文 --是什么样就显示成什么样,说明useUnicode=true&amp;characterEncoding=GBK有起到同一编码的作用,所以应该是从html到jsp编译成的servlet之间出问题了

2.如果在java代码里加入:

类似于这样的:String sort = new String(user.getSort().getBytes("ISO-8859-1"),"UTF-8");

操作数据库就没问题了

3.换成<%@ page contentType="text/html;charset=ISO-8859-1" language="java"%>问题就变成存入数据库的是些byte 码,读出到页面上不会乱码

结论:

1。用native2ascii -encoding gb2312 User_zh_CN.bak User_zh_CN.properties处理的目的是可以同一用UTF-8来编码jsp页面

2。只要在交给业务逻辑代码处理前把编码设置成UTF-8(而不是GB2312!!!! 原来就错在这里,那时没理解透)就可以了

用到了filter,相应到网上搜下一打把.

<filter>

<filter-name>CharacterEncoding</filter-name>

<filter-class>com.lpeng.webapp.base.EncodingFilter</filter-class>

<init-param>

<param-name>encoding</param-name>

<param-value>UTF-8</param-value>

</init-param>

</filter>

<filter-mapping>

<filter-name>CharacterEncoding</filter-name>

<url-pattern>/*</url-pattern>

</filter-mapping>

在这过程学到其他的东西:

1。再遇到困难的时候第一要保持清醒的头脑 用来思考,而不是在没想清楚之前就拼命的猜测测试,然后让把心情搞的坏到骂人

2。decode解码,encode编码,so:

getBytes(String charsetName)

Encodes this String into a sequence of bytes using the named charset, storing the result into a new byte array.

String(byte[] bytes, String charsetName)

Constructs a new String by decoding the specified array of bytes using the specified charset.

就很好理解了

发现的其他问题:

mysql-connector-java-3.0.11-stable-bin.jar

這 jar 有 bug

mysql-connector-java-3.0.10-stable-bin.jar就沒事了

下载地址:http://www.ibiblio.org/maven/mysql/jars/

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航