Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·hibernate配置笔记
·AOP编程入门--Java篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·在win2003下整合了整合Tomcat5.5+ apache_2.0.53+ mod_jk_2.0.47.dll
·构建Linux下IDE环境--Eclipse篇
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·ASP、JSP、PHP 三种技术比较
·Tomcat5.5.9的安装配置
·AWT GUI 设计笔记(二)

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
struts国际化+mysql中文乱码的问题

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

花了三个多小时解决的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/




相关文章

相关软件