- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
正如文档所说:
Filter base class that aims to guarantee a single execution per request dispatch, on any servlet container.
有个问题 What is OncePerRequestFilter?我仍然不知道我们为什么要使用它。
它说“在任何 servlet 容器上”。意思是有servlet容器会不止一次的执行filter?
最佳答案
我已经回答了here还。要了解 OncePerRequestFilter 的作用,我们需要首先清楚地了解普通过滤器的行为方式。当您希望某些特定代码在 servlet 执行之前或之后执行时,您可以创建一个过滤器,其作用如下:
code1 ===> servlet execution (using chain.doFilter()) ===> code2
所以code1在servlet之前执行,code2在servlet执行之后。但是在这里,当 servlet 执行时,可能会有一些其他请求到不同的 servlet,并且那个不同的 servlet 也有这个相同的过滤器。 在这种情况下,此过滤器将再次执行。
OncePerRequestFilter 可防止此行为。对于我们的一个请求,这个过滤器将恰好执行一次(不多也不少)。此行为在使用安全身份验证时非常有用。
关于java - 为什么在 Spring 中使用 OncePerRequestFilter?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35978352/
文档说 org.springframework.web.filter.OncePerRequestFilter “保证每个请求只执行一次”。在什么情况下,每个请求可能会多次执行过滤器? 最佳答案 Un
我有一个 Spring 应用程序(不使用 Spring boot)部署到 tomcat 我尝试使用 OncePerRequestFilter 在给定条件下的特定 URL 上返回错误 401 (Http
我已经发现了一些与此主题相关的问题,但我发现没有一个问题能阐明此主题。 显然 OncePerRequestFilter 确保请求在过滤器链中仅通过一次过滤器,但我不清楚何时会发生相反的情况。 很高兴看
正如文档所说: Filter base class that aims to guarantee a single execution per request dispatch, on any ser
我想从OncePerRequestFilter类访问一个spring组件,但是当我访问服务时得到空指针,我认为原因是配置。 我认为由于配置,过滤器在spring调度程序servlet之前被调用。有什么
我有一个 JWTAuthFilter,它扩展了 OncePerRequestFilter 我正在验证 token 。 validateToken方法抛出自定义异常(CredentialsChanged
public class FlashMapFilter extends OncePerRequestFilter { @Override @SuppressWarnings("unch
我有一个基本的 SpringBoot 2.0.5.RELEASE 应用程序。使用Spring Initializer、JPA、嵌入式Tomcat、Thymeleaf模板引擎,打包为可执行JAR文件。
我有一个扩展 OncePerRequestFilter 的过滤器。当我使用 management.port=8081 和 server.port=8080(或任何不同的端口)时,我的过滤器不会在任何
我有一个扩展 OncePerRequestFilter 的过滤器。当我使用 management.port=8081 和 server.port=8080(或任何不同的端口)时,我的过滤器不会在任何
我已经在我的 springboot 应用程序中实现了 OncePerRequestFilter,但是在添加过滤器 swagger 之后没有打开它给出了 401 错误(这是显而易见的)。我的问题是如何在
我有一个简单的 OncePerRequestFilter 有几个 init-param我的 web.xml 中定义的条目,但我不知道如何从过滤器中访问它们。 getFilterConfig()返回 n
我正在尝试使用 Spring Security 开发具有 JWT 授权的 Spring Boot Rest API。我希望所有请求都通过过滤器来验证 JWT token ,除了应生成 jwt toke
我是一名优秀的程序员,十分优秀!