博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Servlet处理get请求时的中文乱码问题
阅读量:4966 次
发布时间:2019-06-12

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

使用Servlet处理get请求时,如果get请求的参数中有中文,直接接收会是乱码,这个时候需要使用类似下面的语句来处理乱码:

String name = request.getParameter("name");System.out.prinlnt(name); // 乱码 // 处理乱码name = new String(name.getBytes("ISO8859-1"),"UTF-8");System.out.println(name);// 乱码问题解决

 

每次中文都要处理,比较麻烦,可以使用过滤器,使用类型下面的代码处理乱码问题:

public String getParameter(String name) {    String value = super.getParameter(name);    if (value == null)        return null;    String method = request.getMethod();    if ("get".equalsIgnoreCase(method)) {        try {            value = new String(value.getBytes("ISO8859-1"),"UTF-8");        } catch (UnsupportedEncodingException e) {            e.printStackTrace();        }    }    return value;}

为什么我们需要将ISO8859-1转为UTF-8?为什么接收到的参数是ISO8859-1这种编码方式的?

其实很简单,只是个配置问题:
在tomcat安装目录下的conf/server.xml中,有如下的配置:

URIEncoding,该配置决定了使用get请求通过浏览器地址栏访问tomcat时的编码方式,默认的编码方式使ISO8859-1:

URIEncoding:This specifies the character encoding used to decode the URI bytes, after %xx decoding the URL. If not specified, ISO-8859-1 will be used.

可以这样配置,则上述代码中,就不需要再从ISO8859-1转为UTF-8了:

URIEncoding="UTF-8"

 

值得注意的是,从tomcat8.0开始,URIEncoding默认值不再是ISO8859-1,而变成了UTF-8 

那么也就意味着,从tomcat8.0开始,get请求中的中文参数,不需要特殊处理了。而如果是tomcat8之前的项目要迁移到tomcat8上面来,则也需要特殊注意这个问题,可能要删减代码中响应乱码的处理模块了。

 

转载于:https://www.cnblogs.com/guo-rong/p/7611883.html

你可能感兴趣的文章
我对应用软件——美团的看法
查看>>
执行了的程序,才是你的程序.
查看>>
struts2.x + Tiles2.x读取多个xml 配置文件
查看>>
表单校验之datatype
查看>>
python第六篇文件处理类型
查看>>
hdu 3183 A Magic Lamp 贪心
查看>>
ubuntu16系统磁盘空间/dev/vda1占用满的问题
查看>>
面试题14 调整数组顺序使奇数位于偶数前面
查看>>
grid网格布局
查看>>
flask简单的注册功能
查看>>
JSP常用标签
查看>>
dashucoding记录2019.6.7
查看>>
IOS FMDB
查看>>
编码总结,以及对BOM的理解
查看>>
九涯的第一次
查看>>
Android中全屏或者取消标题栏
查看>>
处理器管理与进程调度
查看>>
页面懒加载
查看>>
向量非零元素个数_向量范数详解+代码实现
查看>>
java zip 中文文件名乱码_java使用zip压缩中文文件名乱码的解决办法
查看>>