前述:
在写这篇笔记之前,对笔记中的设计模式进行介绍:
本篇笔记中将要使用到的设计模式是:装饰(包装)设计模式
(1)装饰(包装)设计模式口诀:
①定义一个类,实现被装饰对象的接口
②定义一个成员变量,记住被装饰对象的引用
③定义构造方法,传入被装饰对象的实例
④改写要修改的方法
⑤不需要改写的方法,调用被装饰对象的原来的方法
(2)什么时候使用装饰设计模式
当我们需要对一个类进行增强的时候,增强后的类不再当前类的范畴
例如:现在有一个     Animal类     Cat和Dog都属于动物类型,因此可以直接继承
现在新来一个“电子狗 ”,不属于动物的范围,但是有需要用其中的方法,这时候我们选择使用装饰(包装)设计模式
一:需求:统一解决请求参数中文乱码
二:需求原因:
在没有该需求之前,解决请求乱码问题:
(1)POST:
 1 //第一种
 2 //request.setCharacterEncoding(this.getServletContext().getInitParameter("charset"));
 3 //备注:这种获取方式是因为在web.xml中进行了如下配置
 4      <!-- 设置编码 -->
 5       <context-param>
 6             <param-name>charset</param-name>
 7             <param-value>UTF-8</param-value>
 8       </context-param>
 9
10 //第二种
11 request.setCharacterEncoding("utf-8");

分析:第一种方式的好处是,在context中配置后,项目后期如果需要修改获取方式,直接修改配置文件即可,不要对.java文件进行修改
(2)GET:
1      String value = request.getParameter("value");
2      if(value == null || value.trim().equals("")){
3          value="";
4      }
5      value = new String(value.getBytes("ISO-8859-1"),"utf-8");

三、优化思路:
使用一个过滤器,在请求到达servlet之前,先对request对象设置编码
要求所有的请求都要进行设置编码,因此所有的request都要拦截,进行增强,那么:

1      <filter>
2             <filter-name>EncodingFilter</filter-name>
3             <filter-class>com.cqy.filter.EncodingFilter</filter-class>
4       </filter>
5
6       <filter-mapping>
7             <filter-name>EncodingFilter</filter-name>
8             <url-pattern>/*</url-pattern>
9       </filter-mapping>

四:代码实现:
1、过滤器代码
 1 package com.cqy.filter;
 2
 3 import java.io.IOException;
 4
 5 import javax.servlet.Filter;
 6 import javax.servlet.FilterChain;
 7 import javax.servlet.FilterConfig;
 8 import javax.servlet.ServletException;
 9 import javax.servlet.ServletRequest;
10 import javax.servlet.ServletResponse;
11 import javax.servlet.http.HttpServletRequest;
12 import javax.servlet.http.HttpServletResponse;
13
14 import com.cqy.domain.MyRequest;
15
16 public class EncodingFilter implements Filter {
17
18       @Override
19       public void destroy() {
20
21       }
22
23       @Override
24       public void doFilter(ServletRequest req, ServletResponse res,
25                   FilterChain chain) throws IOException, ServletException {
26             // 将请求和响应强制转换成Http形式
27             HttpServletRequest request = (HttpServletRequest) req;
28             HttpServletResponse response = (HttpServletResponse) res;
29
30             // 处理响应乱码
31             response.setContentType("text/html;charset=utf-8");
32
33             // 自定义一个request对象:MyRequest,对服务器原来的requset进行增强,使用装饰设计模式
34             // 要增强原来的request对象,必须先获取到原来的request对象
35             MyRequest myRequest = new MyRequest(request);
36
37             // 注意:放行的时候应该传入增强后的request对象
38             chain.doFilter(myRequest, response);
39       }
40
41       @Override
42       public void init(FilterConfig arg0) throws ServletException {
43
44       }
45
46 }

2、自定义增强类(MyRequest )
  1 package com.domain;
  2
  3 import java.io.UnsupportedEncodingException;
  4 import java.util.Map;
  5 import java.util.Set;
  6
  7 import javax.servlet.http.HttpServletRequest;
  8 import javax.servlet.http.HttpServletRequestWrapper;
  9
 10 /**
 11  * @author  继承HttpServletRequestWrapper相当于实现了HttpServletRequest
 12  *         HttpServletRequestWrapper类,它本身实现了所有HttpServletRequest的方法
 13  *         继承它之后,需要修改的方法MyRequest可以自己定义,不需要修改的方法,直接使用父类的方法
 14  *
 15  *         第一步:总结:继承HttpServletRequestWrapper,为了偷懒,
 16  *         不用自己去实现所有HttpServletRequest的方法 第二步:使用构造函数将原来的request对象保存到当前自定义对象中
 17  *         第三步:针对要修改的方法,进行增强 第四步:定义一个flag标记,防止编码重复执行
 18  */
 19 public class MyRequest extends HttpServletRequestWrapper {
 20
 21     // 定义了一个成员变量,用来保存构造函数传入的requset对象
 22     private HttpServletRequest request = null;
 23
 24     // 定义一个标记,用来标注:当前requset中,请求参数,是否已经编码过了
 25     private boolean flag = false;
 26
 27     public MyRequest(HttpServletRequest request) {
 28         super(request);
 29         this.request = request;
 30
 31     }
 32
 33     // 总需求:对request对象的获取数据的方法,进行增强(统一编码)
 34
 35     @Override
 36     public Map<String, String[]> getParameterMap() {
 37         // 获得请求方式request.getMethod()方法
 38         String method = this.request.getMethod();
 39         // post请求
 40         if ("post".equalsIgnoreCase(method)) {
 41             // 设置编码格式
 42             try {
 43                 request.setCharacterEncoding("utf-8");
 44             } catch (UnsupportedEncodingException e) {
 45                 e.printStackTrace();
 46             }
 47             Map<String, String[]> map = this.request.getParameterMap();
 48             return map;
 49
 50         } else if ("get".equalsIgnoreCase(method)) {
 51             // get请求
 52             // 分析:get请求需要对每一个参数都进行转换,因此需要对map中的每个元素进行遍历
 53             // 首先获得map集合
 54             Map<String, String[]> map = this.request.getParameterMap();
 55
 56             //第一次获取请求参数,flag==false,执行后面的额乱码处理动作
 57             //第二次获取请求参数的时候,flag==true,不执行后面的处理,直接返回已经编码过的map集合
 58             if (flag) {
 59                 return map;
 60             }
 61             if (map == null) {
 62                 return super.getParameterMap();
 63             } else {
 64                 // 然后获得map集合的key
 65                 Set<String> key = map.keySet();
 66                 // 通过key将map中的元素取出来
 67                 for (String string : key) {
 68                     String[] value = map.get(string);
 69                     // 接下来需要将String中的每一个都进行遍历,转换参数
 70                     for (int i = 0; i < value.length; i++) {
 71                         try {
 72                             String string2 = new String(
 73                                     value[i].getBytes("iso-8859-1"), "utf-8");
 74                             value[i] = string2;
 75                         } catch (UnsupportedEncodingException e) {
 76                             e.printStackTrace();
 77                         }
 78                     }
 79                 }
 80                 flag = true;
 81                 return map;
 82             }
 83         } else {
 84             //位置请求方式,自定义对象处理不了,使用父类的方法处理
 85             return super.getParameterMap();
 86         }
 87     }
 88
 89     @Override
 90     public String[] getParameterValues(String name) {
 91         // 通过map集合获取参数
 92         Map<String, String[]> map = this.getParameterMap();
 93         if (map == null) {
 94             return super.getParameterValues(name);
 95         } else {
 96             String[] strings = map.get(name);
 97             return strings;
 98         }
 99     }
100
101     @Override
102     public String getParameter(String name) {
103         // 通过values获取参数
104         String[] values = this.getParameterValues(name);
105         if (values == null) {
106             return super.getParameter(name);
107         } else {
108             return values[0];
109         }
110     }
111
112 }

转载于:https://www.cnblogs.com/CQY1183344265/p/5863371.html

使用过滤器(Filter)解决请求参数中文乱码问题(复杂方式)相关推荐

  1. ​ SpringMVC表单请求参数的绑定,配置编码过滤器解决请求参数中文乱码问题,自定义类型转换器

    文章目录 ​ SpringMVC的参数绑定支持的数据类型 基本数据类型和字符串类型 JavaBean 包装类 Map类型 List类型 POST请求参数中文乱码的解决方法 自定义类型转换器(Date类 ...

  2. 前端请求参数中文乱码问题

    1.以post方式提交 以post方式提交的请求参数中文乱码问题可以通过后端的编码过滤器解决. 可以直接使用springMVC中的编码过滤器,只需在web.xml中添加过滤器的配置即可. <fi ...

  3. GET方式请求参数中文乱码问题 [JavaWeb][Servlet]

    请求参数中文乱码问题(GET) 同样的我们要解决GET方式下的请求参数中文乱码问题,那么我们首先要知道GET请求方式之下为什么中文数据就会出现乱码? 因为我们GET方式之下的请求参数是在请求行中,是紧 ...

  4. HttpClient4.x中GET方式发送请求参数中文乱码处理

    HttpClient4.x GET 方式发送请求参数中文乱码处理 (非返回结果乱码) 之前尝试对HttpGet对象添加头部字符编码设置均无效,后改用参数字符编码处理后实现请求参数乱码正确处理. Htt ...

  5. 解决: VUE 项目中表单提交中文乱码、接口请求参数中文乱码

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 1. 表单提交出现乱码: 接口请求乱码同于上图. 2. 解决: 在出现乱码的内容外面加函数:deco ...

  6. Request_获取请求参数中文乱码问题处理

    * 中文乱码问题:                 * get方式:tomcat 8 已经将get方式乱码问题解决了                 * post方式:会乱码              ...

  7. request请求参数中文乱码问题

    中文乱码问题解决方案 编码格式不同导致 浏览器填写的是ISO 代码接收的是:utf-8 POST方式修改: POST方式修改: 底层通过getReader() 流的方式获取资源. 只需要setChar ...

  8. [javaweb] servlet处理请求参数中文乱码的问题

    对于post请求方式: 在获取参数代码之前加上下面这一句代码就可以 request.setCharacterEncoding("UTF-8"); 不然的话中文就是乱码

  9. SpringBoot解决redirect参数中文乱码问题

    代码如下:&name=" + new URLEncoder().encode(user.getName(), Charset.defaultCharset()) ;只需要将中文参数e ...

最新文章

  1. 在python3环境安装builtwith模块
  2. 用 js判断 一个数是否是素数(质数)_2020-09-20:如何判断一个数是质数?
  3. 数据库SQL面试题七则
  4. webapi同时支持post和get报404错误
  5. delphi 中的dll编程注意事项
  6. 建立http服务器,基于名称的虚拟主机
  7. python基本词汇的特点_开课吧老师为你讲解 Python都有什么优点?
  8. 【经验之谈】Git使用之TortoiseGit配置VS详解
  9. 【写作技巧】中文摘要及关键词的撰写
  10. 基于Linux下 Oracle 备份策略(RMAN)
  11. 基于物品的协同过滤mysql_百万用户,八十万商品,如何计算基于物品的协同过滤...
  12. 【转】C#获取用户桌面等特殊系统路径
  13. Spring MVC深入讲解
  14. python 框选截图_python实现微信的区域截图功能
  15. 【Java合并图片】使用Java实现两张图片合并成一张图片的功能(水平合并、垂直合并、透明背景颜色)
  16. su - root 切换失败
  17. 快讯 | 公链专场,四位大咖分享了些什么(附PPT)
  18. 社群运营中品牌化和IP化运营实践
  19. Machine Learning – 第2周(Linear Regression with Multiple Variables、Octave/Matlab Tutorial)
  20. js移动端rem.js自适应布局代码

热门文章

  1. BBSSDK插件技术方案
  2. 过年回家应对七大姑八大姨,程序猿绝了!
  3. Jmeter学习(三)
  4. 2_tabbar底部切换
  5. Ubuntu开启远程连接
  6. android 显示 PDF 文件
  7. Linux~上部署.net MVC出现的问题与解决
  8. 推荐系统(1)--splitting approaches for context-aware recommendation
  9. stat用法:获取文件对应权限的数字
  10. Windows IIS