博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Tomcat中文编码
阅读量:5026 次
发布时间:2019-06-12

本文共 1296 字,大约阅读时间需要 4 分钟。

本来以为把jsp页面设置为UTF-8,服务器端用filter把request和response设置为utf-8,中文问题应该就差不多了。

但tomcat似乎中间给我我们加了步骤。

1 页面

页面中设置的编码,我们post的数据就会按照页面的编码进行 encode,

比如 我们要post数据为 site=博客园,如果我们的页面为utf-8格式,

则实际post的数据为 site=%E5%8D%9A%E5%AE%A2%E5%9B%AD

java:URLEncoder.encode("博客园", "utf-8"),

所以我们post给服务器的数据会先经过页面编码的encode。

2 tomcat服务器

当我们直接 request.getParameter(“site”);发现得到的字符串为“?????????”,

因为tomcat自作聪明的把的字符串当成iso8859-1来解码了,

tomcat执行了类似:URLDecoder.decode(str, "iso8859-1");,因为jsp页面默认的编码就是iso8859-1,

就算你改了myeclipse的jsp页面默认编码,但tomcat的还是iso8859-1。

3 servlet

我们的servlet如何得到中文编码呢?我们一步一步的加码解码即可:

URLEncoder.encode(str, "iso8859-1");//把tomcat给我们解码的字符串给加码上

URLDecoder.decode(str, "utf-8");//把浏览器给我们加码的数据解码

 

总体过程:

//页面 pageEncoding=utf-8		String str = "博客园";		str = URLEncoder.encode(str, "utf-8");		System.out.println(str);		//output:%E5%8D%9A%E5%AE%A2%E5%9B%AD				//tomcat 		str = URLDecoder.decode(str, "iso8859-1");		System.out.println(str);		//output:?????????				// servlet		str = URLEncoder.encode(str, "iso8859-1");		System.out.println(str);//%E5%8D%9A%E5%AE%A2%E5%9B%AD		str = URLDecoder.decode(str, "utf-8");		System.out.println(str);//博客园

 

知道了tomcat加码解码过程,我们就可以彻底设置解码方式了。

如果是get方式传数据,可以设置解码方式,

在tomcat的server.xml中 connector加上解码方式:

post还是使用filter + 手动解码吧!

转载于:https://www.cnblogs.com/syxchina/archive/2011/11/15/2249690.html

你可能感兴趣的文章
【Github教程】史上最全github使用方法:github入门到精通
查看>>
抽象工厂模式(Abstract Factory)
查看>>
luogu1373 小a和uim之大逃离 (dp)
查看>>
Redis的Pub/Sub客户端实现
查看>>
SQL日常问题和技巧——持续更新
查看>>
springMVC入门(一)------springMVC基本概念与安装
查看>>
Sam做题记录
查看>>
[bzoj] 2453 维护数列 || 单点修改分块
查看>>
IIS版本变迁
查看>>
BZOJ3884: 上帝与集合的正确用法 拓展欧拉定理
查看>>
mybatis09--自连接一对多查询
查看>>
myeclipse10添加jQuery自动提示的方法
查看>>
【eclipse jar包】在编写java代码时,为方便编程,常常会引用别人已经实现的方法,通常会封装成jar包,我们在编写时,只需引入到Eclipse中即可。...
查看>>
视频监控 封装[PlayCtrl.dll]的API
查看>>
软件工程APP进度更新
查看>>
Python 使用正则替换 re.sub
查看>>
CTF中那些脑洞大开的编码和加密
查看>>
简化工作流程 10款必备的HTML5开发工具
查看>>
c++ 调用外部程序exe-ShellExecuteEx
查看>>
Java进击C#——语法之知识点的改进
查看>>