java中文乱码转码不成功、pl/sql数据库中文乱码、get提交方式中文乱码
2015-11-25 12:05
267 查看
(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编码。
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编码。
相关文章推荐
- Java中Scanner类方法简介
- JAVA 大数相乘
- Java实现监听USB插入
- 如何搭建struts框架
- eclipse的某些设置及快捷键
- Java源码剖析之server2008上拉不出验证码
- 【struts2】Result和ResultType
- Java 泛型方法
- struts中no result define for ×××Action
- SSH学习之——Spring、Struts和Hibernate整合开发
- java包命名规则
- Eclipse C 补全设置
- 关于Spring Transaction的笔记
- GEF中组合按键设置汇总以及org.eclipse.gef.KeyStroke的方法的使用
- Java定时任务以及ScheduledThreadPoolExecutor需要注意的问题
- java性能优化的一些注意点。。。
- Java构建字符串
- Spring 开启Annotation <context:annotation-config> 和 <context:component-scan>诠释及区别
- eclipse项目迁移到android studio(图文最新版)
- java上转型