欢迎来到至成科技_西安服务器托管_西安服务器租用_西安域名注册
029-89390727
时间:2014-10-31  来源:至成科技  作者:SEOR  点击次数:1005

在使用JSP虚拟主机时较使人头疼的问题就是中文乱码问题,JSP虚拟主机的中文乱码问题怎么解决呢?下面笔者分享我在软件开发过程中遇到的乱码问题及其解决办法。 

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

    数据库里本来是正常的,但用JAVA连接后,一经提取,就全乱了。 

    解决方案:修改JAVA连接数据库的URL,加上或者修改URL中的编码为UTF-8,characterEncoding=UTF-8,若是hibernate的配置问题,jdbc连接url不能有&符号,会导致出错或者后面不生效,我用&代替就好了。 

    不要以为用的是GB2312这里就指定为GB2312(个人认为若指定为GB2312,驱动又多做了快速编码转换,所以就又成了乱码了)当然,也可能驱动太旧等情况。 

    POST提交表单是乱码 

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

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

    解决方案: 

    1、修改配制来完成 

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

    2、自己写编码转换程序 

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

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

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"; 





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

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

    数据库中本来就是乱码 

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

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

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

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

    以上几种常见的乱码问题,你遇见过吗?我觉得以上的JSP虚拟主机的乱码问题应该95%以上都在上面了,如果你遇到什么不一样的问题,欢迎留言分享你的经验及其解决办法。 


西安网站建设-至成科技光放微信
陕西本土非营利性IDC互联网接入商/  Shanxi Local nonprofit IDC Internet access provider

公司地址:西安市经开区凤城四路西安国际企业中心B座23层06-10室

全国咨询热线(TEL): 029-89390727

7*24小时售前咨询电话 :
029-89390727   029-63390892   029-63390961
029-68090209

7*24小时售后服务电话 : 029-89393039

Top