拦截器被叫2倍以上

时间:2019-07-02 06:14:07

标签: java spring internationalization interceptor

我使用Spring i18n库。
-ReloadableResourceBundleMessageSource
-SessionLocaleResolver
-LocaleChangeInterceptor

没有错误。 如果我在chrome中使用了强大的刷新功能,则所有拦截器方法都会执行两次。 并且仅当使用页面的messages.properties时,才会发生“问题”。

preHandle ==>控制器==> postHandle ==>执行AfterCompletion之后,所有方法又执行两次。

我已经看了拦截器的生命周期,但是我不明白为什么拦截器无缘无故地运行两次。


1. servlet-context.xml

<beans:bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
    <beans:property name="basenames" value="/WEB-INF/messages/messages, /WEB-INF/messages/messages_ko_KR" />
</beans:bean>    
<beans:bean id="localeResolver" class="org.springframework.web.servlet.i18n.SessionLocaleResolver">
    <beans:property name="defaultLocale" value="ko_KR" />
</beans:bean>
<interceptors>
    <beans:bean id="localeChangeInterceptor" class="com.test.util.locale.LocaleChangeInterceptor" />
</interceptors>


2. LocaleChangeInterceptor由我实现,并且实现简单,如下代码所示。

public class LocaleChangeInterceptor extends HandlerInterceptorAdapter {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {

        String language = request.getParameter("language");

        System.out.println("1. preHandle(): " + language);

        if(language != null) {
            LocaleResolver localeResolver = RequestContextUtils.getLocaleResolver(request);
            localeResolver.setLocale(request, response, StringUtils.parseLocaleString(language));
        }

        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
            ModelAndView modelAndView) throws Exception {
        System.out.println("2. postHandle()");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        System.out.println("3. afterCompletion()");
    }
}


控制台

1. preHandle(): null
main.jsp
2. postHandle()
3. afterCompletion()
1. preHandle(): null
2. postHandle()
3. afterCompletion()
1. preHandle(): null
2. postHandle()
3. afterCompletion()

我不知道这是Interceptor生命周期的问题还是自然结果。

1 个答案:

答案 0 :(得分:0)

已解决。 通过首先创建一个Interceptor bean来解决此问题, 然后通过从引用调用已注册的bean。

这似乎是个问题,因为我对Spring拦截器注册不甚了解。我需要了解更多。

<beans:bean id="localeChangeInterceptor" class="com.test.util.locale.LocaleChangeInterceptor" />

<interceptors>
    <interceptor>
        <mapping path="/**" />
        <exclude-mapping path="/resources/**" />
        <beans:ref bean="localeChangeInterceptor" />
    </interceptor>
</interceptors>