Spring перехватчик не вызывается
Я начал работать с пружинными перехватчиками и хотел просто записать время вызова каждого запроса.
Мой класс перехватчика:
package com.ankit.notice.interceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
public class ExecuteTimeInterceptor extends HandlerInterceptorAdapter{
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
long startTime = System.currentTimeMillis();
System.out.println("Time is " + startTime);
return true;
}
}
корневой context.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- Root Context: defines shared resources visible to all other web components -->
<context:component-scan base-package="com.ankit.notice" />
<mvc:annotation-driven></mvc:annotation-driven>
<mvc:interceptors>
<bean class="com.ankit.notice.interceptor.ExecuteTimeInterceptor" />
</mvc:interceptors>
.....
</beans>
Класс контроллера
@RequestMapping(value = "api/getAllItems.rest", method = RequestMethod.GET)
public ResponseEntity<Map<String, Object>> getAllItems(
HttpServletRequest request, HttpServletResponse response, HttpSession session) {
ResponseEntity<Map<String, Object>> responseEntity = null;
Map<String, Object> responseParams = new HashMap<String, Object>();
try {
User user = (User) session.getAttribute("user");
if ((null == user) || (user.getId() < 0)) {
throw new MNPSessionException(
"INVALID USER : Session attribute user is not set correctly");
}
....
}
У меня нет сопоставления запросов для класса контроллера, вместо этого я сопоставляю запросы непосредственно с методами. (Я знаю, что это плохая практика, но я работаю над этим:))
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<!-- The definition of the Root Spring Container shared by all Servlets and Filters -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/root-context.xml</param-value>
</context-param>
<context-param>
<param-name>defaultHtmlEscape</param-name>
<param-value>true</param-value>
</context-param>
<!-- Creates the Spring Container shared by all Servlets and Filters -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- Processes application requests -->
<servlet>
<servlet-name>appServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/appServlet/servlet-context.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>appServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>appServlet</servlet-name>
<url-pattern>*.htm</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>appServlet</servlet-name>
<url-pattern>*.json</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>appServlet</servlet-name>
<url-pattern>*.rest</url-pattern>
</servlet-mapping>
<filter>
<filter-name>sessionCheckFilter</filter-name>
<filter-class>com.ankit.notice.util.SessionCheckFilter</filter-class>
</filter>
filter-mapping>
<filter-name>sessionCheckFilter</filter-name>
<url-pattern>*</url-pattern>
</filter-mapping>
</web-app>
Запросить URL localhost:8080/mvc/api/getAllItems.rest
Насколько я понимаю, так как в mvc:interceptors
тег, перехватчик должен быть вызван для всех запросов.
В моей консоли нет доступных выходов sysout. Я попытался вернуть false, чтобы убедиться, что нет проблем с перехватчиками и sysout, но безрезультатно.
Также я попытался удалить удаление mvc:annotation-driven
тег, но перехватчик не вызывается.
Любые указатели, что здесь может быть не так? Были и другие варианты, такие как создание бина класса BeanNameUrlHandlerMapping
и создание боба класса RequestMappingHandlerMapping
со свойствами: list
а также mapping
, но ни один из них не работает. Может ли кто-нибудь указать на разницу между этими методами и дать указания, когда их использовать?
2 ответа
Чтобы "переопределить" перехватчик, я использовал класс конфигурации, аннотированный @Configuration (созданный внутри пакета "config").
Там нет необходимости использовать любую конфигурацию XML.
package com.abc.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.Ordered;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import com.abc.interceptor.BaseInterceptor;
@Configuration
public class WebConfig extends WebMvcConfigurerAdapter {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new BaseInterceptor());
}
}
Я клянусь, что вы забыли тег "mvc:interceptor" внутри тега "mvc:interceptors":
Не могли бы вы попробовать следующее?
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean id="executeTimeInterceptor" class="com.ankit.notice.interceptor.ExecuteTimeInterceptor" />
</mvc:interceptor>
</mvc:interceptors>