Potrebbe aiutare a controllare perché doFilter non sempre chiamatodoFilter non sempre chiamato
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>
firma classe:
import org.springframework.web.filter.GenericFilterBean;
public class RoseFilter extends GenericFilterBean {
404 viene restituito, mentre chiamata http://localhost:8080/hello/world, ho imposta i punti di interruzione su doFilter, sembra che doFilter non abbia chiamato? (Ho provato tomcat 6.0.18, 6.0.29, jdk1.6)
La risoluzione '/ hello/world' è una risorsa per il server? In caso contrario, non vi è alcun motivo per avviare una catena di filtri. – rsp
Sono abbastanza sicuro di averlo già visto prima, con lo schema '/ *' non funzionante. Non penso di averlo mai risolto. – skaffman
@rsp: la risorsa non deve necessariamente essere una risorsa fisica esistente. Il filtro (e il servlet) mappati su '/ *' saranno invocati comunque. Potrebbe agire come un front controller. – BalusC