gpt4 book ai didi

java - doFilter 没有被调用

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

你能帮忙看看为什么doFilter没有被调用吗

web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/log4j.properties</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
<filter>
<filter-name>roseFilter</filter-name>
<filter-class>net.paoding.rose.RoseFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>roseFilter</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
<dispatcher>INCLUDE</dispatcher>
</filter-mapping>
</web-app>

类签名:

import org.springframework.web.filter.GenericFilterBean;
public class RoseFilter extends GenericFilterBean {

调用 http://localhost:8080/hello/world 时返回 404 , 我将断点设置在 doFilter,好像没有调用doFilter?(我试过tomcat 6.0.18、6.0.29、jdk1.6)

最佳答案

在以下情况下不会调用过滤器:

  1. 类路径中缺少过滤器类和/或不可加载或实例化。但是,您应该在服务器的启动日志中注意到它。根据对服务器日志中发现的异常/错误的解释来找到解决方案。

  2. 链中之前运行的另一个过滤器未调用 FilterChain#doFilter() ,而是 RequestDispatcher#forward() include() 这导致链中的后续过滤器被完全跳过(当它们不监听 FORWARDINCLUDE 调度程序时;它们默认只监听 REQUEST 调度程序)。解决方案要么修复错误的过滤器,要么添加 <dispatcher>FORWARD</dispatcher>等等,或者重新排列 web.xml 中的过滤器声明这样您的新过滤器就会出现在另一个过滤器之前(您只需确保您的新过滤器正确使用 FilterChain#doFilter() :))。

  3. 请求 URL 完全错误。您使用了 http://localhost:8080/hello/world .使用过滤器监听 /* ,这意味着 webapp 上下文应该是 ROOT 或者至少是 /hello .验证您的 webapp 上下文。我只是重试一个 URL,该 URL 指向生成非 404 响应的同一个 webapp 中的有效 JSP/Servlet。然后过滤器也会被调用吗?

关于java - doFilter 没有被调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3659683/

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