- 浏览: 101173 次
- 性别:
- 来自: 北京
文章分类
最新评论
query = new String(query.getBytes("iso8859-1"), "utf-8");
从开始接触J2EE,中文参数传递乱码问题一直伴随着我们,回忆一下我自己的解决过程吧。
各位转载请著名出处哦:http://hi.baidu.com/hyh8774
一:首先学到的解决方法是在页面中request.setCharacterEncoding(“GB18030”)来设置请求的编码为中文编码,然后就在每个需要接收参数的页面噼里啪啦的写上这么一句,对当时的水平来说虽然累却也开心。
二:后来开始做分页程序了,突然发现必须得用URL传参了,也就是要用GET方法传参了,那就用吧,程序里照样来request.setCharacterEncoding(“GB18030”)这么一句,然后大失所望,传进来的中文参数(搜索的关键字)出现乱码了,开始郁闷了,查资料才发现原来在 tomcat4 和 tomcat5 中队参数的处理是不一样的,在 tomcat4 中 get 与 post 的编码是一样的,然而,在 tomcat5 中,get 与 post 的处理是分开进行的。那咋办呢?继续Google,得到的答案是字符转码,来这么一句new String( request.getParameter("para").getBytes("iso8859-1"), "gb18030");发现OK了,高兴!然后遇到类似的中文参数就转啊转的,感觉世界不那么美好了!这还不累死人啊,一会GET转,一会POST转,痛苦!
三:后来,大家开始写一个过滤器,在取得客户端传过来的参数之前,通过过滤器首先将取得的参数编码设定为 gb18030 ,然后就可以直接使用 getParameter 取得正确的参数了。这个过滤器在 tomcat 有示例代码,方便了,感觉世界美好了些,不用每个页面写request.setCharacterEncoding了,但是上面遇到的第二个问题任然没有解决啊,只要是GET方式的中文传参,还得转码。。。先用着吧。。。谁叫Tomcat美国人写的呢。。。
四:不过还好,在 tomcat 5 中,为了解决编码问题,tomcat 的作者作了很多努力,具体表现为在 tomcat 的配置文件 server.xml 中对 Connector 元素增加了如下的配置参数,专门用来对编码进行直接的配置 URIEncoding=”GB18030” 用来设定通过 URI 传递的内容使用的编码,tomcat 将使用这里指定的编码对客户端传送的内容进行编码。当然对POST方法还得在过滤器中设置request编码。另一个参数是useBodyEncodingForURI = true设置为true后,只要在页面中request.setCharacterEncoding(“GB18030”)那么无论GET还是POST方式的中文传参都不会出现问题,所以useBodyEncodingForURI = true加过滤器算是一个很好的中文传参解决方法了。
五:上面的方法虽然好,但是对项目的可移植性来说太差了,毕竟咱现在做的些个小项目还没有用专门的web服务器,你让人家服务器就为你一个小屁项目修改自己配置文件,那别人的项目咋办?如果是远程的服务器就更麻烦了。所以还是把这些个处理放到自己的程序中吧。
六:接下来的就是本人现在采用的解决方案,仍然是过滤器,也是本人写这篇文章的中心所在,常规的过滤器只对POST方式有效,所以当请求方式为GET时考虑重写request.getParameter() 和request.getParameterValues()方法,在自己的方法中将中文转码,既然要重写,而ServletRequest为接口,那么自然得有实现了,我们就继承实现它的类HttpServletRequestWrapper吧,这样外部的JSP/SERVLET就不需要做任何处理了,可谓一劳永逸,呵呵!
好了,还是来看一下具体的代码吧:
过滤器CharsetAllEncodingFilter.java
package filters;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
public class CharsetAllEncodingFilter implements Filter {
private String encoding = null;
/**
* Request.java 对 HttpServletRequestWrapper 进行扩充, 不影响原来的功能并能提供所有的
* HttpServletRequest 接口中的功能. 它可以统一的对 Tomcat 默认设置下的中文问题进行解决而只需要用新的 Request
* 对象替换页面中的 request 对象即可.
*/
class Request extends HttpServletRequestWrapper {
private String encoding = null;
public Request(HttpServletRequest request) {
super(request);
encoding = CharsetAllEncodingFilter.this.encoding;
}
/**
* 转换由表单读取的数据的内码. 从 ISO 字符转到 在web.xml中设置的encoding.
*/
public String toChi(String input) {
if(input == null) {
return null;
} else {
try {
byte[] bytes = input.getBytes("ISO8859-1");
return new String(bytes, encoding);
} catch (Exception ex) {
}
return null;
}
}
/**
* Return the HttpServletRequest holded by this object.
*/
private HttpServletRequest getHttpServletRequest() {
return (HttpServletRequest) super.getRequest();
}
/**
* 读取参数 -- 修正了中文问题.
*/
public String getParameter(String name) {
return toChi(getHttpServletRequest().getParameter(name));
}
/**
* 读取参数列表 - 修正了中文问题.
*/
public String[] getParameterValues(String name) {
String values[] = getHttpServletRequest().getParameterValues(name);
if (values != null) {
for (int i = 0; i < values.length; i++) {
values[i] = toChi(values[i]);
}
}
return values;
}
}
public void destroy() {
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpreq = (HttpServletRequest) request;
if (httpreq.getMethod().equals("POST")) {
request.setCharacterEncoding(encoding);
} else {
request = new Request(httpreq);
}
chain.doFilter(request, response);
}
public void init(FilterConfig filterConfig) throws ServletException {
encoding = filterConfig.getInitParameter("encoding");
}
}
接下来配置web.xml
<filter>
<filter-name>CharsetEncodingFilter</filter-name>
<filter-class>filters.CharsetAllEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GB18030</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharsetEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
引文来源 [原创]超强过滤器彻底解决JSP/SERVLET中文参数GET/POST传递的问题_Lings百度空间 for J2EE | SSH/Struts2/Tapestry/JSF/iBATIS/EJB/SQL/Ajax/Linux
从开始接触J2EE,中文参数传递乱码问题一直伴随着我们,回忆一下我自己的解决过程吧。
各位转载请著名出处哦:http://hi.baidu.com/hyh8774
一:首先学到的解决方法是在页面中request.setCharacterEncoding(“GB18030”)来设置请求的编码为中文编码,然后就在每个需要接收参数的页面噼里啪啦的写上这么一句,对当时的水平来说虽然累却也开心。
二:后来开始做分页程序了,突然发现必须得用URL传参了,也就是要用GET方法传参了,那就用吧,程序里照样来request.setCharacterEncoding(“GB18030”)这么一句,然后大失所望,传进来的中文参数(搜索的关键字)出现乱码了,开始郁闷了,查资料才发现原来在 tomcat4 和 tomcat5 中队参数的处理是不一样的,在 tomcat4 中 get 与 post 的编码是一样的,然而,在 tomcat5 中,get 与 post 的处理是分开进行的。那咋办呢?继续Google,得到的答案是字符转码,来这么一句new String( request.getParameter("para").getBytes("iso8859-1"), "gb18030");发现OK了,高兴!然后遇到类似的中文参数就转啊转的,感觉世界不那么美好了!这还不累死人啊,一会GET转,一会POST转,痛苦!
三:后来,大家开始写一个过滤器,在取得客户端传过来的参数之前,通过过滤器首先将取得的参数编码设定为 gb18030 ,然后就可以直接使用 getParameter 取得正确的参数了。这个过滤器在 tomcat 有示例代码,方便了,感觉世界美好了些,不用每个页面写request.setCharacterEncoding了,但是上面遇到的第二个问题任然没有解决啊,只要是GET方式的中文传参,还得转码。。。先用着吧。。。谁叫Tomcat美国人写的呢。。。
四:不过还好,在 tomcat 5 中,为了解决编码问题,tomcat 的作者作了很多努力,具体表现为在 tomcat 的配置文件 server.xml 中对 Connector 元素增加了如下的配置参数,专门用来对编码进行直接的配置 URIEncoding=”GB18030” 用来设定通过 URI 传递的内容使用的编码,tomcat 将使用这里指定的编码对客户端传送的内容进行编码。当然对POST方法还得在过滤器中设置request编码。另一个参数是useBodyEncodingForURI = true设置为true后,只要在页面中request.setCharacterEncoding(“GB18030”)那么无论GET还是POST方式的中文传参都不会出现问题,所以useBodyEncodingForURI = true加过滤器算是一个很好的中文传参解决方法了。
五:上面的方法虽然好,但是对项目的可移植性来说太差了,毕竟咱现在做的些个小项目还没有用专门的web服务器,你让人家服务器就为你一个小屁项目修改自己配置文件,那别人的项目咋办?如果是远程的服务器就更麻烦了。所以还是把这些个处理放到自己的程序中吧。
六:接下来的就是本人现在采用的解决方案,仍然是过滤器,也是本人写这篇文章的中心所在,常规的过滤器只对POST方式有效,所以当请求方式为GET时考虑重写request.getParameter() 和request.getParameterValues()方法,在自己的方法中将中文转码,既然要重写,而ServletRequest为接口,那么自然得有实现了,我们就继承实现它的类HttpServletRequestWrapper吧,这样外部的JSP/SERVLET就不需要做任何处理了,可谓一劳永逸,呵呵!
好了,还是来看一下具体的代码吧:
过滤器CharsetAllEncodingFilter.java
package filters;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
public class CharsetAllEncodingFilter implements Filter {
private String encoding = null;
/**
* Request.java 对 HttpServletRequestWrapper 进行扩充, 不影响原来的功能并能提供所有的
* HttpServletRequest 接口中的功能. 它可以统一的对 Tomcat 默认设置下的中文问题进行解决而只需要用新的 Request
* 对象替换页面中的 request 对象即可.
*/
class Request extends HttpServletRequestWrapper {
private String encoding = null;
public Request(HttpServletRequest request) {
super(request);
encoding = CharsetAllEncodingFilter.this.encoding;
}
/**
* 转换由表单读取的数据的内码. 从 ISO 字符转到 在web.xml中设置的encoding.
*/
public String toChi(String input) {
if(input == null) {
return null;
} else {
try {
byte[] bytes = input.getBytes("ISO8859-1");
return new String(bytes, encoding);
} catch (Exception ex) {
}
return null;
}
}
/**
* Return the HttpServletRequest holded by this object.
*/
private HttpServletRequest getHttpServletRequest() {
return (HttpServletRequest) super.getRequest();
}
/**
* 读取参数 -- 修正了中文问题.
*/
public String getParameter(String name) {
return toChi(getHttpServletRequest().getParameter(name));
}
/**
* 读取参数列表 - 修正了中文问题.
*/
public String[] getParameterValues(String name) {
String values[] = getHttpServletRequest().getParameterValues(name);
if (values != null) {
for (int i = 0; i < values.length; i++) {
values[i] = toChi(values[i]);
}
}
return values;
}
}
public void destroy() {
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpreq = (HttpServletRequest) request;
if (httpreq.getMethod().equals("POST")) {
request.setCharacterEncoding(encoding);
} else {
request = new Request(httpreq);
}
chain.doFilter(request, response);
}
public void init(FilterConfig filterConfig) throws ServletException {
encoding = filterConfig.getInitParameter("encoding");
}
}
接下来配置web.xml
<filter>
<filter-name>CharsetEncodingFilter</filter-name>
<filter-class>filters.CharsetAllEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GB18030</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharsetEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
引文来源 [原创]超强过滤器彻底解决JSP/SERVLET中文参数GET/POST传递的问题_Lings百度空间 for J2EE | SSH/Struts2/Tapestry/JSF/iBATIS/EJB/SQL/Ajax/Linux
发表评论
-
Deployment failure on Tomcat 6.x.
2012-03-06 17:56 854在用MyEclipse6.5做项目时发现这样的问题:Deplo ... -
页面缓存时间设置
2012-02-22 12:45 0http://www.go2pad.com/space-201 ... -
url 中文转码
2012-02-20 11:10 2647我想,URL传参中文对于程序员来说,是个很头疼的问题吧。虽然在 ... -
html meta
2011-12-02 11:16 692meta是用来在HTML文档中模拟HTTP协议的响应头报文。m ... -
css
2011-12-02 10:54 1747一、如何创建 CSS插入样 ... -
JDK&JRE区别
2011-11-28 18:28 717对于java初学者来说,往往不懂区分jdk和jre的区别,实际 ... -
jsp页面不缓存
2011-11-25 09:01 807html <meta http-equiv =& ... -
将双引号(“”) 存入数据库的处理方法
2011-11-15 20:00 801将双引号(“”) 存入数据库的处理方法: 例如 :“恐男症”女 ... -
解决时分秒不能写入Date类型字段中
2011-11-02 18:48 1076CallableStatement cstmt = null; ... -
StringBuffer内容清空效率比较
2011-10-31 18:08 827在开发程序的时候,经常使用StringBuffer来进行字符串 ... -
tl标签常用方法
2011-10-31 17:46 788函数名 函数说明 使用举例 fn:contains 判断 ... -
Test.java
2011-10-21 11:44 633Test.java右键Run as RUN CONFIGUR ... -
myeclipse把maven普通java项目变成web项目的全程操作
2011-10-20 11:47 804http://apps.hi.baidu.com/share/ ... -
用线程调用方法
2011-10-13 16:25 796package nkc.util; import ... -
json转换为java对象
2011-10-11 19:43 1745json数组格式 [{},{}] 转换 List<Li ... -
java 事件
2011-10-10 10:10 7281.创建事件源 EventSource source = ne ... -
LazySingleton 单例模式
2011-10-10 10:00 802public class LazySingleton{ ... -
EventObject类
2011-10-10 09:31 1606开发者经常要基于Observer模式创建事件监听系统(Even ... -
复合优先于继承
2011-09-26 08:33 782继承是代码重用的有力武器,但是它并不是完成这项工作的最佳工具, ... -
Quartz Cron Expression
2011-08-16 09:34 786Quartz Cron Expression 原文解释: ...
相关推荐
总结,"超强过滤器"是解决JSP-Servlet之间中文参数GET-POST传递问题的有效手段,通过统一设定请求的字符编码,确保在整个Web应用中中文数据能够正确无误地传输和处理。对于大型项目,这样的全局解决方案可以大大提升...
### Servlet过滤器解决乱码问题 在Web应用开发过程中,字符编码问题经常出现,尤其是在处理中文等多字节字符时。如果不正确地设置字符编码,可能会导致页面显示乱码。本文将详细介绍如何通过Servlet过滤器来解决这...
总的来说,通过在过滤器中设置合适的字符编码,我们可以有效地解决JSP应用中请求参数中文乱码的问题。需要注意的是,选择哪种字符编码取决于你的应用需求,不同的编码可能会适用于不同的环境和用户群体。此外,如果...
在这个场景下,我们需要创建一个专门的过滤器来解决GET请求的编码问题。 首先,我们需要了解HTTP协议的基本知识。HTTP请求的GET方法是通过URL来传递参数的,这些参数与URL本身一起被编码。默认情况下,浏览器使用...
JSP利用过滤器解决request中文乱码问题 JSP中requestgetParameter中文乱码问题是经常遇到的问题,解决这个问题有多种方法,但利用过滤器解决request中文乱码问题是其中最有效的一种方法。本文将详细介绍如何使用...
### javaweb servlet(jsp)的乱码问题原理及解决 #### HTTP协议的基本理解与乱码问题背景 HTTP协议作为互联网应用中最为广泛使用的通信协议之一,它定义了客户端和服务端之间的交互规则。HTTP请求主要分为GET和...
- `web.xml`文件是Web应用的核心配置文件,用于声明和配置Servlet、过滤器等。 - 模板示例: ```xml <servlet> <servlet-name>myServlet</servlet-name> <servlet-class>com.example.MyServlet</servlet-class...
在JSP开发中,中文乱码问题是一个常见的挑战...通过理解过滤器的工作原理并正确地在开发中应用,我们可以有效地避免JSP开发中的中文乱码问题,提高用户体验。同时,这也是提升Java Web应用性能和安全性的常用手段之一。
【标题】"51603205_51603060.rar_Jsp/Servlet_Java__Jsp/Servlet_Java_" 暗示了这个压缩包文件包含的是关于Java Web开发,特别是JSP(JavaServer Pages)和Servlet的相关教程或资料。这些技术是用于构建动态网站和...
本文将详细介绍如何在Servlet与JSP中彻底解决中文乱码问题,并给出具体的解决方案。 #### 二、中文乱码的原因分析 中文乱码主要由以下几个原因引起: 1. **服务器端编码设置不正确**:如果服务器端的字符集设置与...
在Java Web开发中,尤其是在处理中文参数时,经常会遇到一个常见问题——**jspservlet取参数乱码**。这一现象通常发生在当用户从客户端提交包含中文字符的表单至服务器端时,服务器端接收到的参数显示为乱码。这种...
标题“编码过滤器”直指这一关键概念,而描述“配置在web.xml中的过滤器,支持过滤GET,POST方式提交的参数”则进一步明确了这种过滤器的作用范围。 在Web应用中,GET和POST是两种主要的HTTP请求方法,它们用来从...
`web.xml`是部署描述符,定义了Servlet的映射、过滤器和监听器等配置。 2. **JSP文件**:这些文件包含了用户界面和部分业务逻辑。JSP中的Java代码可以定义变量、执行逻辑操作,并通过EL(Expression Language)和...
3. **数据传递**:Servlet可以通过`request.setAttribute()`将处理结果存储在请求或session中,然后使用JSP的EL(Expression Language)或JSTL(JavaServer Pages Standard Tag Library)标签来获取并展示数据。...
对于POST请求中的中文参数,可以使用过滤器来统一处理编码问题。过滤器只对POST请求有效,对于GET请求则无效。具体实现方式如下: ```java public class EncodingFilter implements Filter { @Override public ...
`ch10`和`ch11`可能涉及到了Servlet的过滤器和监听器;`ch12`可能涵盖了JSP的基础语法;`ch15`至`ch19`可能讲解了更高级的主题,如EL(Expression Language)、JSTL(JavaServer Pages Standard Tag Library)、MVC...
3. **配置Web应用**:设置web.xml文件,定义Servlet映射、过滤器和监听器等组件。 4. **数据库交互**:使用JDBC连接MySQL,执行CRUD(创建、读取、更新、删除)操作,处理结果集。 5. **事务管理**:在需要时,确保...
在JSP中,Servlet可以通过内置对象实现后端逻辑,如`request`、`response`对象用于获取和设置请求参数以及发送响应,`session`对象用于维护用户会话,`application`对象用于在整个应用范围内的数据共享。...
当你遇到“找不到javax.servlet.*”这样的错误时,通常是因为你的项目缺少了这个库,所以需要引入`javax.servlet.jar`来解决问题。 1. **Java Servlet简介** Java Servlet是Java平台上的一个标准,用于扩展服务器...
2. **Servlet基础**:讲解Servlet生命周期、Servlet API的使用、过滤器和监听器的应用。 3. **JSP与Servlet的交互**:介绍如何在JSP中调用Servlet,以及Servlet如何转发或重定向到JSP。 4. **会话管理**:利用...