花了三个多小时解决的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&characterEncoding=GBK
现象: 1.数据库里是中文也能显示成中文 --是什么样就显示成什么样,说明useUnicode=true&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/

|