快速业务通道

Java认证:JSP虚拟主机使用中的乱码问题

作者 佚名技术 来源 互联网 浏览 发布时间 2012-01-18

为了方便广大考生更好的复习,帮考网综合整理提供了Java认证:JSP虚拟主机使用中的乱码问题,以供各位考生考试复习参考,希望对考生复习有所帮助。

JSP虚拟主机使用中的乱码问题

在使用JSP的过程中,最使人头疼的一个问题就是中文乱码问题,以下是我在软件开发中遇到的乱码问题以及解决方法。

1 POST提交表单是乱码

常见的情况为:页面都正常,但新插入的数据全是乱码。

这种情况,就是因为提交的数据被程序接收后就是乱码,这个乱码又插入数据库了,所以显示不正常

解决方案:

a 修改配制来完成

修改tomcat的配制文件server.xml中的连接器,加上URIEncoding=“GB2312”就OK了

b 自己写编码转换程序

b.a 在与表单交换数据的时候,做转换,这种方式灵活

每一个页面请求写一个转换,或者写一个公共的类,在接收的时候,都做一下转移,代码如下:

public static String ISOGBChange(String s)

{

return EncodeChange(s,“ISO8859-1”,“GB2312”);

}

public static String EncodeChange(String s,String source_encode,String dest_encode)

{

if(s==null)

return null;

try

{

byte[] tmpbyte = s.getBytes(source_encode); s = new String(tmpbyte,dest_encode);

return s;

}

catch (Exception e)

{

return “ERROR”;

}

}

b.b 使用tomcat的web.xml中定义的过滤器filter来转换所有的请求编码

这个需要自己去研究一下过滤器的写法,再具体的转换编码,还是b.a中的代码进行编码转换的,只是转移不用再写在每个程序中了。

2 数据库中本来就是乱码

就是说数据库里面的数据本来就是乱码,无论您用什么编码连接数据库,查看到的都是乱码。如何确定数据库中本来就是乱码呢?(其实也不太容易确定,我们仅给出一个大概的判断)

您用客户端连接数据库的时候,一定要选择连接编码为GB2312,UTF-8,ISO-8859-1等常见的编码格式,连接并查看您的表中内容是不是正常的,若没有一种情况是正常的,应该就可以判定为乱码了。

当然,这个判定并不标准,甚至问题很多,但在国内,我想99%以上都用这几种编码。所以我认为这个判定准确性是可以被接受的。

解决方案:您用客户端连接数据库的时候,一定要选择连接编码为GB2312或者GBK,然后于重新执行数据库脚本,保证数据库里保存的是正常的字符。而不是乱码

3 从数据库提取出来就是乱码

数据库里本来是正常的,但用JAVA连接

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号