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的生命周期里,拦截器可以多起调用,而过滤器只能在容器初始化时调用一次。

  • 相关阅读:
    密码保护
    实现搜索功能
    完成个人中心—导航标签
    个人中心标签页导航
    评论列表显示及排序,个人中心显示
    完成评论功能
    从首页问答标题到问答详情页
    首页列表显示全部问答,完成问答详情页布局。
    JavaScript Array Reduce用于数组求和
    【Angular5】 返回前一页面 go back to previous page
  • 原文地址:https://www.cnblogs.com/shenhaha520/p/9739288.html
Copyright © 2011-2022 走看看