【问题标题】:CharacterEncodingFilter not set with spring-boot 1.2.0 and spring-boot-legacyCharacterEncodingFilter 未使用 spring-boot 1.2.0 和 spring-boot-legacy 设置
【发布时间】:2023-03-26 05:20:01
【问题描述】:

我在 tomcat (servlet 2.5) 中运行传统的春季启动战。这些请求没有任何编码集,尽管 CharacterEncodingFilter 默认配置为 spring-boot 1.2.0。我可以看到它在自动配置和日志中配置。也许这不是由 spring-boot-legacy (1.0.1) 配置的?我将过滤器添加到 web.xml,我的请求现在具有 utf-8 编码。但是,这不适用于请求参数。我认为这是因为它不是访问请求的第一个过滤器(尽管它是我的 web.xml 中的第一个过滤器,它基于 spring-boot-legacy 示例)。在我失败的请求的堆栈跟踪中,我确实将 OncePerRequestFilter 视为第一个过滤器。有没有办法解决这个问题?

org.springframework.boot.actuate.autoconfigure.MetricFilterAutoConfiguration$MetricsFilter.doFilterInternal(MetricFilterAutoConfiguration.java:90) [spring-boot-actuator-1.2.0.RELEASE.jar:1.2.0.RELEASE]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) [spring-web-4.1.3.RELEASE.jar:4.1.3.RELEASE]
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:344) [spring-web-4.1.3.RELEASE.jar:4.1.3.RELEASE]
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:261) [spring-web-4.1.3.RELEASE.jar:4.1.3.RELEASE]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) [catalina.jar:7.0.53]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) [catalina.jar:7.0.53]
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) [spring-web-4.1.3.RELEASE.jar:4.1.3.RELEASE]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) [spring-web-4.1.3.RELEASE.jar:4.1.3.RELEASE]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) [catalina.jar:7.0.53]

web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">

    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>com.myproject.Application</param-value>
    </context-param>

    <listener>
        <listener-class>org.springframework.boot.legacy.context.web.SpringBootContextLoaderListener</listener-class>
    </listener>

    <filter>
      <filter-name>characterEncodingFilter</filter-name>
      <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
      <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>characterEncodingFilter</filter-name>
      <url-pattern>/*</url-pattern>
    </filter-mapping>

    <filter>
        <filter-name>metricFilter</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>metricFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

    <servlet>
        <servlet-name>appServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextAttribute</param-name>
            <param-value>org.springframework.web.context.WebApplicationContext.ROOT</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>appServlet</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>
</web-app>

谢谢, 哈里。

【问题讨论】:

  • 你能发布你的 web.xml 吗?
  • 您没有使用DelegatingFilterProxy 进行字符编码的任何原因(bean 名称是“characterEncodingFilter”)?
  • @DaveSyer:虽然参数解码仍然没有发生,但我做出了改变。同时,我认为我还没有理解 spring-boot-legacy 的范围。我以为所有的 Spring Boot 过滤器也是由 spring-boot-legacy 配置的。看来我必须向 web.xml 添加任何必需的过滤器。
  • 当然你必须在 web.xml 中添加过滤器(Servlet 2.5 就是这样)。但是对于最初的问题:我认为CharacterEncodingFilter 无论如何都不会对请求参数进行编码(它只是设置标头)。

标签: spring-boot


【解决方案1】:

2 条建议:

  1. 使用DelegatingFilterProxy 进行字符编码(bean 名称为“characterEncodingFilter”)。

  2. 1234563

【讨论】:

  • 谢谢。我意识到两件事 1. 我将编码与 URL 编码混淆了。所以 characterEncodingFilter 在这种情况下不是我的解决方案。 2. 我需要手动将 spring boot 过滤器添加到我的 web.xml 中(可能很明显,但对我来说不是 :)。提供一个包含所有此类过滤器的示例 web.xml 可能会有所帮助,尤其是排序。我去添加了 hiddenHttpMethodFilter 和 webRequestLoggingFilter (因为跟踪不再工作)。
猜你喜欢
  • 2014-07-26
  • 1970-01-01
  • 1970-01-01
  • 2018-07-05
  • 2023-03-13
  • 1970-01-01
  • 2018-07-11
  • 1970-01-01
  • 2017-04-08
相关资源
最近更新 更多