(1)Java文件中文乱码?
gbk编码的字节数组按utf8编解码是不可逆的;
utf8编码的字节数组按gbk编解码是不可逆的;
而gbk或utf8按iso8859-1编解码是可逆的。
原因是utf8 编码是3字节表示汉字,gbk编码是双字节表示汉字,iso8859-1 就是所谓的拉丁字符,是单字节的,无法表示汉字。
按照可逆不可逆的规则顺序转码,就可以成功了。
(2)PL/SQL数据库中文乱码?
解决方案:设置系统环境变量
变量名:NLS_LANG
变量值:SIMPLIFIED CHINESE_CHINA.ZHS16GBK
(3)get提交方式中文乱码?
<%@ page language="java" contentType="text/html;charset=utf-8" pageEncoding="utf-8"%>
这样,就统一了编码为utf-8。
这种方式在post提交表单中含有中文时没有问题。但是在用get提交时,如果含有中文,就会出现类似于“? ? ?”的乱码问题。造成这种现象的原因是Tomcat对get和post两种提交方式的处理方法不一样造成的。自从Tomcat5.x开始,GET和POST方法提交的信息,Tomcat采用了不同的方式来处理编码,对于POST请求,Tomcat会仍然使用request.setCharacterEncoding方法所设置的编码来处理,如果未设置,则使用默认的iso-8859-1编码。而GET请求则不同,Tomcat对于GET请求并不会考虑使用request.setCharacterEncoding方法设置的编码,而会永远使用iso-8859-1编码。