String name=request.getParameter("name").toString
![](/icons/19453kh.gif)
;
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln("转换前
![](/icons/19453de.gif)
姓名:"+name);
//采用枚举法测试
//
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln("111111"+
![](/icons/19453new.gif)
String(name.getBytes("ISO-8859-1"),"gb2312"));
//
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(
![](/icons/19453new.gif)
String(name.getBytes("UTF-8"),"gb2312"));
//
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(
![](/icons/19453new.gif)
String(name.getBytes("GB2312"),"gb2312"));
//
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(
![](/icons/19453new.gif)
String(name.getBytes("GBK"),"gb2312"));
//
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(
![](/icons/19453new.gif)
String(name.getBytes("BIG5"),"gb2312"));
//此处必须转换成中文
![](/icons/19453zifu.gif)
集
![](/icons/19453dou.gif)
这个地方和数据库
![](/icons/19453zifu.gif)
集是有关系
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
是
![](/icons/19453yi.gif)
![](/icons/19453yi.gif)
对应
![](/icons/19453de.gif)
![](/icons/19453byte.gif)
![](/icons/19453byte.gif)
s = name.getBytes("ISO-8859-1");
String result =
![](/icons/19453new.gif)
String(
![](/icons/19453byte.gif)
s, "gb2312");
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln("转换后
![](/icons/19453de.gif)
姓名:"+result);
开发java应用出现乱码是很常见
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
毕竟现在unicode
![](/icons/19453de.gif)
使用还不是很广泛
![](/icons/19453dou.gif)
在使用gb2312(包含了gbk简体
![](/icons/19453dou.gif)
big5繁体)
![](/icons/19453de.gif)
系统中要正确实现
中文
![](/icons/19453de.gif)
display和数据库
![](/icons/19453de.gif)
存储是最基本
![](/icons/19453de.gif)
要求
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
1
![](/icons/19453dou.gif)
首先developer要明确自己为什么会遇到乱码
![](/icons/19453dou.gif)
遇到什么样
![](/icons/19453de.gif)
乱码(无意义
![](/icons/19453de.gif)
符号还是
![](/icons/19453yi.gif)
串问号或者其它什么东西)
新手遇到
![](/icons/19453yi.gif)
堆很乱
![](/icons/19453de.gif)
![](/icons/19453zifu.gif)
时通常不知所措
![](/icons/19453dou.gif)
最直接
![](/icons/19453de.gif)
反映就是打开google搜索”java中文”(这个
![](/icons/19453zifu.gif)
串在搜索引擎上
![](/icons/19453de.gif)
查询频率非常高)
然后
![](/icons/19453yi.gif)
个
![](/icons/19453yi.gif)
个
![](/icons/19453de.gif)
去看别人
![](/icons/19453de.gif)
解决方法
![](/icons/19453dou2.gif)
这样做没有错
![](/icons/19453dou.gif)
但是很难达到目
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
原因下面会提到
总之
![](/icons/19453dou.gif)
出现乱码
![](/icons/19453de.gif)
原因是非常多
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
解决
![](/icons/19453de.gif)
方法也完全不
![](/icons/19453yi.gif)
样
![](/icons/19453dou.gif)
要解决问题必须先分析自己
![](/icons/19453de.gif)
”上下文环境”
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
2
![](/icons/19453dou.gif)
具体说来
![](/icons/19453dou.gif)
需要哪些信息才能确定项目中
![](/icons/19453de.gif)
乱码
![](/icons/19453de.gif)
根源
a
![](/icons/19453dou.gif)
开发者所用
![](/icons/19453de.gif)
操作系统
b
![](/icons/19453dou.gif)
j2ee容器
![](/icons/19453de.gif)
名称
![](/icons/19453dou.gif)
版本
c
![](/icons/19453dou.gif)
数据库
![](/icons/19453de.gif)
名称
![](/icons/19453dou.gif)
版本(精确版本)以及jdbc驱动
![](/icons/19453de.gif)
版本
d
![](/icons/19453dou.gif)
出现乱码
![](/icons/19453de.gif)
source code(比如是system out 出来
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
还是jsp页面中
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
如果是jsp中
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
那么头部声明
![](/icons/19453de.gif)
情况也很重要)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
![](/icons/19453dd.gif)
=
3
![](/icons/19453dou.gif)
如何初步分析乱码出现
![](/icons/19453de.gif)
原因
有了上述
![](/icons/19453de.gif)
信息
![](/icons/19453dou.gif)
基本上就可以发帖求助了
![](/icons/19453dou.gif)
相信放到javaworld等论坛上
![](/icons/19453dou.gif)
很快就会有高手给你提出有效
![](/icons/19453de.gif)
解决方案
![](/icons/19453de.gif)
当然不能总靠发帖求助
![](/icons/19453dou.gif)
也要试试自行解决问题
![](/icons/19453dou2.gif)
如何下手呢?
a
![](/icons/19453dou.gif)
分析
![](/icons/19453yi.gif)
下你
![](/icons/19453de.gif)
”乱码”到底是什么编码
![](/icons/19453dou2.gif)
这个其实不难
![](/icons/19453dou.gif)
比如
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(testString);
这
![](/icons/19453yi.gif)
段出现了乱码
![](/icons/19453dou.gif)
那么不妨用穷举法猜测
![](/icons/19453yi.gif)
下它
![](/icons/19453de.gif)
实际编码格式
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(
![](/icons/19453new.gif)
String(testString.getBytes(”ISO-8859-1″),”gb2312″));
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(
![](/icons/19453new.gif)
String(testString.getBytes(”UTF8″),”gb2312″));
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(
![](/icons/19453new.gif)
String(testString.getBytes(”GB2312″),”gb2312″));
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(
![](/icons/19453new.gif)
String(testString.getBytes(”GBK”),”gb2312″));
![](/icons/19453System.gif)
.out.pr
![](/icons/19453int.gif)
ln(
![](/icons/19453new.gif)
String(testString.getBytes(”BIG5″),”gb2312″));
等等
![](/icons/19453dou.gif)
上述代码
![](/icons/19453de.gif)
意思是用制定
![](/icons/19453de.gif)
编码格式去读取testString这个”乱码”
![](/icons/19453dou.gif)
并转换成gb2312(此处仅以中文为例)
然后你看哪
![](/icons/19453yi.gif)
个转换出来
![](/icons/19453de.gif)
结果是ok
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
那就
![](/icons/19453dou2.gif)
![](/icons/19453dou2.gif)
b
![](/icons/19453dou.gif)
如果用上面
![](/icons/19453de.gif)
步骤能得到正确
![](/icons/19453de.gif)
中文
![](/icons/19453dou.gif)
说明你
![](/icons/19453de.gif)
数据肯定是在
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
只不过是界面中没有正确显示而已
![](/icons/19453dou2.gif)
那么第二步就该纠正你
![](/icons/19453de.gif)
view部分了
![](/icons/19453dou.gif)
通常需要检查
![](/icons/19453de.gif)
是jsp中是否选择了正确
![](/icons/19453de.gif)
页面编码
在此要声明被很多人误解
![](/icons/19453de.gif)
![](/icons/19453yi.gif)
点
![](/icons/19453dou.gif)
那就是<%@ page contentType=”text/html; char
![](/icons/19453set.gif)
=GB2312″ %>指令和<META http-equiv=Content-Type
content=”text/html; char
![](/icons/19453set.gif)
=gb2312″>两者
![](/icons/19453de.gif)
不同
![](/icons/19453dou2.gif)
通常网上
![](/icons/19453de.gif)
很多文章在提到中文问题时都是说数据库中选择unicode或者gb2312存储
![](/icons/19453dou.gif)
同
时在jsp中用page指令声明编码就可以解决
![](/icons/19453dou2.gif)
但是我觉得这种说法很不负责任
![](/icons/19453dou.gif)
害
![](/icons/19453de.gif)
我费了N多时间为本来并不存在
![](/icons/19453de.gif)
乱码而郁闷
![](/icons/19453dou2.gif)
实际上page
![](/icons/19453de.gif)
作用是在jsp被编译成为html
![](/icons/19453de.gif)
过程中提供编码方式让java来”读取”表达式当中
![](/icons/19453de.gif)
String(有点类似于上面
![](/icons/19453de.gif)
第三个语句
![](/icons/19453de.gif)
作用)
![](/icons/19453dou.gif)
而meta
![](/icons/19453de.gif)
作用是众所周知
![](/icons/19453de.gif)
为IE浏览器提供编码选择
![](/icons/19453dou.gif)
是用来”显示”最后
![](/icons/19453de.gif)
数据
![](/icons/19453de.gif)
![](/icons/19453dou2.gif)
但是没有看到有人提醒这
![](/icons/19453yi.gif)
点
![](/icons/19453dou.gif)
我
![](/icons/19453yi.gif)
直把page当成meta在用
导致本来是iso-8859
![](/icons/19453de.gif)
数据
![](/icons/19453dou.gif)
被page指令读成gb2312
![](/icons/19453dou.gif)
于是乱码
![](/icons/19453dou.gif)
所以又加了编码转化
![](/icons/19453de.gif)
![](/icons/19453hanshu.gif)
把所有
![](/icons/19453de.gif)
![](/icons/19453string.gif)
数据都从iso8859转到gb2312(为
什么这么转
![](/icons/19453dou.gif)
当时也没考虑这么多
![](/icons/19453dou.gif)
![](/icons/19453yinwei.gif)
这么做可以正常显示了
![](/icons/19453dou.gif)
所以就这么改了
![](/icons/19453dou.gif)
呵呵当时实在没有时间慢慢排查问题了)
4
![](/icons/19453dou.gif)
数据库选择什么样
![](/icons/19453de.gif)
编码比较好
目前流行
![](/icons/19453de.gif)
DB主要有sql server
![](/icons/19453dou.gif)
mysql
![](/icons/19453dou.gif)
oracle
![](/icons/19453dou.gif)
DB2等
![](/icons/19453dou.gif)
其中mysql作为免费DB中
![](/icons/19453de.gif)
老大
![](/icons/19453dou.gif)
性能和功能是得到公认
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
安装配置比较方便
![](/icons/19453dou.gif)
相
应
![](/icons/19453de.gif)
driver也比较完善
![](/icons/19453dou.gif)
性价比是绝对
![](/icons/19453de.gif)
OK
![](/icons/19453dou2.gif)
所以就以mysql为例
我个人建议采用mysql
![](/icons/19453de.gif)
默认编码来存储
![](/icons/19453dou.gif)
也就是iso-8859-1(在mysql
![](/icons/19453de.gif)
选项中对应于latin-1)
![](/icons/19453dou2.gif)
理由主要有这么几个
![](/icons/19453dou.gif)
![](/icons/19453yi.gif)
是iso-8859-1对中
文
![](/icons/19453de.gif)
支持不错;二是跟java中
![](/icons/19453de.gif)
默认编码
![](/icons/19453yi.gif)
致
![](/icons/19453dou.gif)
至少在很多地方免除了转换编码
![](/icons/19453de.gif)
麻烦;三是默认
![](/icons/19453de.gif)
比较稳定
![](/icons/19453dou.gif)
兼容性也更好
![](/icons/19453dou.gif)
![](/icons/19453yinwei.gif)
多编码
支持是由具体
![](/icons/19453de.gif)
DB产品提供
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
别说跟其它
![](/icons/19453de.gif)
DB会不兼容
![](/icons/19453dou.gif)
即使自身
![](/icons/19453de.gif)
不同版本也可能出现兼容性
![](/icons/19453de.gif)
问题
例如mysql 4.0以前
![](/icons/19453de.gif)
产品中
![](/icons/19453dou.gif)
很多中文
![](/icons/19453de.gif)
解决方案是利用connection中
![](/icons/19453de.gif)
characterEncoding字段来制定编码
![](/icons/19453dou.gif)
比如gb2312什么
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
这样是ok
![](/icons/19453de.gif)
![](/icons/19453dou.gif)
![](/icons/19453yinwei.gif)
原数据都是ISO8859_1编码
![](/icons/19453dou.gif)
jdbc驱动会采用url里面指定
![](/icons/19453de.gif)
character
![](/icons/19453set.gif)
来进行编码
![](/icons/19453dou.gif)
resultSet.getString(*)取出
![](/icons/19453de.gif)
就是编码后