在使用JSP的过程中
最使人头疼的一个问题就是中文乱码问题
以下是我在软件开发中遇到的乱码问题以及解决方法
POST提交表单是乱码 常见的情况为:页面都正常但新插入的数据全是乱码
这种情况就是因为提交的数据被程序接收后就是乱码这个乱码又插入数据库了所以显示不正常
解决方案: a 修改配制来完成
修改tomcat的配制文件serverxml中的连接器加上URIEncoding=GB就OK了
b 自己写编码转换程序
ba 在与表单交换数据的时候做转换这种方式灵活
每一个页面请求写一个转换或者写一个公共的类在接收的时候都做一下转移代码如下:
public static String ISOGBChange(String s)
{
return EncodeChange(sISOGB);
}
public static String EncodeChange(String sString source_encodeString dest_encode)
{
if(s==null)
return null;
try
{
byte[] tmpbyte = sgetBytes(source_encode); s = new String(tmpbytedest_encode);
return s;
}
catch (Exception e)
{
return ERROR;
}
}
bb 使用tomcat的webxml中定义的过滤器filter来转换所有的请求编码
这个需要自己去研究一下过滤器的写法再具体的转换编码还是ba中的代码进行编码转换的只是转移不用再写在每个程序中了
数据库中本来就是乱码 就是说数据库里面的数据本来就是乱码无论您用什么编码连接数据库查看到的都是乱码如何确定数据库中本来就是乱码呢?(其实也不太容易确定我们仅给出一个大概的判断)
您用客户端连接数据库的时候一定要选择连接编码为GBUTFISO等常见的编码格式连接并查看您的表中内容是不是正常的若没有一种情况是正常的应该就可以判定为乱码了
当然这个判定并不标准甚至问题很多但在国内我想%以上都用这几种编码所以我认为这个判定准确性是可以被接受的
解决方案:您用客户端连接数据库的时候一定要选择连接编码为GB或者GBK然后于重新执行数据库脚本保证数据库里保存的是正常的字符而不是乱码
从数据库提取出来就是乱码
数据库里本来是正常的但用JAVA连接后一经提取就全乱了
解决方案:修改JAVA连接数据库的URL加上或者修改URL中的编码为UTFcharacterEncoding=UTF若是hibernate的配置问题jdbc连接url不能有&符号会导致出错或者后面不生效我用&代替就好了
不要以为用的是GB这里就指定为GB(个人认为若指定为GB驱动又多做了一次编码转换所以就又成了乱码了)
当然也可能驱动太旧等情况
上面只说了常见的几种乱码问题%以上的应该都是上面讲到的还有很多情况就需要您自己慢慢分析了