文档章节

javaWeb项目编码问题探索

一缕清风
 一缕清风
发布于 2016/07/12 18:38
字数 819
阅读 107
收藏 2

这两天遇到了javaweb项目中乱码的问题,想趁此机会搞搞清楚,顺便把过程记录下来,方便以后查看。

首先新建一个动态javaweb工程,写两个jsp,index.jsp和a.jsp,如下图



启动项目,由于表单里的值默认是中文,不出意外,均显示乱码


我们常规的做法就是在b.jsp页面上的request内置对象中设置编码:


再次提交,发现post请求正常了,但是get请求仍不正常


这是怎么回事呢?这个疑问先放着,继续往下探索,将b.jsp中做一些改变:


再看post和get方式的提交结果:


根据以上现象,我们可以得出两个结论:

1.request.setCharacterEncoding()方式的编码过滤只对post请求起作用,get请求并没有起作用;

2.不管是post请求还是get请求,项目中接收到的参数都是“ISO-8859-1”编码的;

有些人就要问了,这个“ISO-8859-1”肯定是哪里配置的吧,ok,这个确实是可配置的,打开tomcat安装目录/conf/server.xml,找到:

<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />

在此节点后追加属性URIEncoding="UTF-8":

<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="UTF-8"/>

查看$TOMCAT_HOME/webapps/tomcat-docs/config/http.html这个说明文档,有如下说明:  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.  也就是说,如果没有设置URIEncoding, Tomcat默认是按ISO-8859-1进行URL解码,ISO-8859-1并未包括中文字符,这样的话中文字符肯定就不能被正确解析了。

将b.jsp复原至最初的状态后再次测试(由于使用eclipse自动部署仅重启tomcat貌似无法让server.xml中的改动生效,为得到正确结果不影响判断,从此处改为导出war包后加入tomcat的webapps目录下手动启动tomcat):


再次运行结果可以发现,post请求为乱码,get请求好了:


这个结果验证了之前的解释,URIEncoding属性的值代表着 Tomcat进行URL解码时的字符集(默认为"ISO-8859-1"),即get请求,但其并不影响post请求,post请求依据的字符编码为request.getCharacterEncoding()的值,默认也为"ISO-8859-1"(但不清楚该默认值是否可更改),如此一来,此属性和编码过滤器配合使用,即可实现get和post请求均正常显示。


.

另外介绍一个参数useBodyEncodingForURI,useBodyEncodingForURI:This specifies if the encoding specified in contentType should be used for URI query parameters, instead of using the URIEncoding.当该参数设置为true时,get请求的编码方式也将根据request.getCharacterEncoding()的值来确定,和URIEncoding的区别在于可为不同url路径设置不同的编码(感觉一般人不会这么干,最多是为同一个tomcat下的不同项目设置不同的编码),如此一来,将此方法设置为true,并设置好编码过滤,即request.setCharacterEncoding(),也可以使整个项目的编码统一。

<Connector port="8080" protocol="HTTP/1.1" 
               connectionTimeout="20000" 
               redirectPort="8443" useBodyEncodingForURI="true" />



参考博客(推荐阅读):http://blog.csdn.net/hengyunabc/article/details/17053585

    http://www.ruanyifeng.com/blog/2010/02/url_encoding.html

                  http://blog.csdn.net/superch0054/article/details/9325793

本文转载自:http://blog.csdn.net/baokx/article/details/50526272

共有 人打赏支持
一缕清风
粉丝 5
博文 128
码字总数 3410
作品 0
东城
私信 提问
java项目与UCenter整合

我想将一个javaWeb项目与UCenter整合,下载了 discuz-ucenter-api-for-java并部署到自己的javaWeb系统里面,可是用测试类调试的时候,出现Exception in thread "main" java.lang.NumberForm...

葡萄枝
2014/01/27
1K
3
JSP笔记——简单javaWeb的文件结构

创建简单javaWeb的步骤: ①在Tomcat下的WebApps创建项目目录 ②编写index.jsp ③创建WEB-INF目录 ④测试运行 ①在Tomcat下的WebApps创建项目目录 创建项目目录myhome ②编写index.jsp ③创建...

努力学习ding
2018/05/17
0
0
Eclipse中Tomcat配置问题

前言: 昨天用javaSE手动部署了一个servlet,本以为自己已经初步窥探了,结果一用eclipse生成javaweb项目 然后部署到Tomcat就问题多多。这一天也算是栽在这上面了。 java后台自学ing的弊端就...

codingcoge
2018/06/07
0
0
java项目与javaweb项目导入jar包的区别

现在的项目基本上都是java web项目,所以导入jar包会出现问题,主要介绍一下java项目与javaweb项目的区别: java项目: 在classLoader加载jar和class的时候,是分开加载的,一般jar导入分两种: 1.在...

低调的AckMan
2015/12/11
1K
0
JavaWeb开发基础

1、应用服务器 Java的应用服务器:Tomcat,JBoss,WebSphere,WebLogic,Resin。这里主要以Tomcat为主。 Tomcat的安装: 1.1、下载Tomcat(http://tomcat.apache.org/) 1.2、在环境变量中设...

pmos
2016/08/15
35
0

没有更多内容

加载失败,请刷新页面

加载更多

发布xxl-job executor dotnet core 执行器的实现

DotXxlJob [github][https://github.com/xuanye/DotXxlJob] xxl-job的dotnet core 执行器实现,支持XXL-JOB 2.0+ 1 XXL-JOB概述 [XXL-JOB][1]是一个轻量级分布式任务调度平台,其核心设计目标...

假正经哥哥
今天
2
0
mysql 查询当天、本周,本月,上一个月的数据

今天 select * from 表名 where to_days(时间字段名) = to_days(now()); 昨天 SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1 近7天 SELECT * FROM 表名 wher......

BraveLN
今天
3
0
Spring 事务初始化源码分析

相关文章 Spring 事务使用详解 Spring AOP 创建代理的源码解析 Spring AOP 注解方式源码解析 Spring AOP 功能使用详解 Spring 的 getBean 方法源码解析 Spring bean 创建过程源码解析 Spring...

TSMYK
今天
1
0
Android Multimedia框架总结(六)C++中MediaPlayer的C/S架构

前面几节中,都是通过java层调用到jni中,jni向下到c++层并未介绍 看下Java层一个方法在c++层 MediaPlayer后续过程 frameworks/av/media/libmedia/MediaPlayer.cpp 找一个我们之前熟悉的setDa...

天王盖地虎626
今天
3
0
【Linux】【MySQL】CentOS7安装最新版MySQL8.0.13(最新版MySQL从安装到运行)

1、前言   框框博客在线报时:2018-11-07 19:31:06   当前MySQL最新版本:8.0.13 (听说比5.7快2倍)   官方之前表示:MySQL 8.0 正式版 8.0.11 已发布,MySQL 8 要比 MySQL 5.7 快 2 ...

Code辉
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部