bạn có thể giúp kiểm tra lý do tại sao doFilter không nhận được gọi làdoFilter không nhận được gọi
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>
lớp chữ ký:
import org.springframework.web.filter.GenericFilterBean;
public class RoseFilter extends GenericFilterBean {
404 được trả về khi gọi http://localhost:8080/hello/world, tôi thiết lập các điểm ngắt tại doFilter, có vẻ như doFilter không được gọi? (Tôi đã thử tomcat 6.0.18, 6.0.29, jdk1.6)
Có '/ hello/world' giải quyết thành tài nguyên cho máy chủ của bạn không? Nếu không, không có lý do gì để bắt đầu một chuỗi bộ lọc. – rsp
Tôi khá chắc chắn rằng tôi đã đi qua điều này bản thân mình trước đây, với mô hình '/ *' không hoạt động. Tôi không nghĩ rằng tôi đã bao giờ giải quyết nó. – skaffman
@rsp: tài nguyên không nhất thiết phải là nguồn tài nguyên hiện có. Tuy nhiên, bộ lọc (và servlet) được ánh xạ trên '/ *' sẽ được gọi ra. Nó có thể là hành động như một bộ điều khiển phía trước. – BalusC