zoukankan      html  css  js  c++  java
  • CharacterEncodingFilter详解及源码解析

    字符编码过滤器  (Spring框架对字符编码的处理)

    基于函数回调,对所有请求起作用,只在容器初始化时调用一次,依赖于servlet容器.

    web.xml配置文件

      <filter>
      <filter-name>Set Character Encoding</filter-name>
      <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
      <async-supported>true</async-supported>
      <init-param>
      <param-name>encoding</param-name>
      <param-value>UTF-8</param-value>
      </init-param>
      <init-param>
      <param-name>forceEncoding</param-name>
      <param-value>true</param-value>
      </init-param>
      </filter>
      <filter-mapping>
      <filter-name>Set Character Encoding</filter-name>
      <url-pattern>/*</url-pattern>
      </filter-mapping>

    其中encoding用来设置编码格式,forceEncoding用来设置是否理会 request.getCharacterEncoding()方法,设置为true则强制覆盖之前的编码格式。

    查看CharacterEncodingFilter源码,可以看出forceEncoding设置为true,强制覆盖之前的编码格式.

      protected void doFilterInternal(
        HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
        throws ServletException, IOException {

        if (this.encoding != null && (this.forceEncoding || request.getCharacterEncoding() == null)) {
            request.setCharacterEncoding(this.encoding);
          if (this.forceEncoding) {
            response.setCharacterEncoding(this.encoding);
          }
        }
        filterChain.doFilter(request, response);
      }

    与过滤器的区别

    过滤器可以简单理解为“取你所想取”,忽视掉那些你不想要的东西;拦截器可以简单理解为“拒你所想拒”,关心你想要拒绝掉哪些东西,比如一个BBS论坛上拦截掉敏感词汇。
    1.拦截器是基于java反射机制的,而过滤器是基于函数回调的。
    2.过滤器依赖于servlet容器,而拦截器不依赖于servlet容器。
    3.拦截器只对action起作用,而过滤器几乎可以对所有请求起作用。
    4.拦截器可以访问action上下文、值栈里的对象,而过滤器不能。
    5.在action的生命周期里,拦截器可以多起调用,而过滤器只能在容器初始化时调用一次。

  • 相关阅读:
    [Hapi.js] Route parameters
    [Hapi.js] Logging with good and good-console
    [Hapi.js] Up and running
    [Unit Testing] Directive testing, require parent controller
    数学-盲点题:九个点用四条直线连起来
    汉语-词语-思维:思维方法
    汉语-词语-思维:思维方式
    汉语-词语:思维
    思考方式-数学-盲点题:盲点题
    摄像机-哈苏:哈苏
  • 原文地址:https://www.cnblogs.com/shenhaha520/p/9739288.html
Copyright © 2011-2022 走看看