gpt4 book ai didi

java - Servlet 过滤器 - 不要将过滤器应用于特定过滤器

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:00:11 27 4
gpt4 key购买 nike

我有一个 Web 应用程序,其登录屏幕由身份验证过滤器提供支持。

我的 web.xml 中有以下内容

<filter>
<filter-name>AuthenticationFilter</filter-name>
<display-name>AuthenticationFilter</display-name>
<filter-class>com.mycompany.secutity.AuthenticationFilter</filter-class>
</filter>

我有以下映射-

<filter-mapping>
<filter-name>AuthenticationFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

但现在我想为特定的 servlet /web/MyNewServlet 添加一个异常(exception),我想绕过身份验证过滤器。我们如何做到这一点?

最佳答案

有两种方法可以做到这一点:

  • /* 模式重新映射到另一个模式,如 /subdir/*,从而避免将 AuthenticationFilter 应用于 /web/MyNewServlet。这是一个繁琐的过程,因为您的 Web 应用程序中可能有多个 URL 现在需要重新映射。我建议在您的开发早期或当您没有太多要重新映射的 URL 时这样做。
  • 以编程方式在您的过滤器实现中包含排除规则。您将需要使用 HttpServletRequest.getServletPath和类似的方法来验证 URL 片段是否包含 /web/MyNewServlet,然后将过滤器链接到下一个过滤器或 servlet,而不是执行过滤器的主体。

关于java - Servlet 过滤器 - 不要将过滤器应用于特定过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7154433/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com