问题描述
通过debug模式发现每次执行controller的请求,请求都是先进入controller方法
然后才进入Interceptor拦截器方法
问题分析及解决方法
通过上图分析可知,拦截器实际上拦截的并不是controller请求,而是/favicon.ico请求。由此可知该拦截器拦截不了controller请求。
通过查阅资料得知是因为<mvc:annotation-driven/>
标签有默认的拦截器,它已经注册了一个DefaultAnnotationHandlerMapping ,自己定义的拦截器优先级没有它高,导致不会调用自己定义的拦截器。
由于我把<mvc:annotation-driven/>
标签写在了applicationContext配置文件中,我首先试着在web.xml中把springmvc-config的配置写在applicationContext配置上面,重新部署项目,发现还是拦截不到controller请求,查阅资料发现:
applicationContext.xml是随ContextLoaderListener的加载而执行的,
而springmvc-config.xml是随DispatcherServlet的加载而执行的,
在web.xml中,加载顺序是listener>filter>servlet
所以applicationContext.xml先加载!
于是,我将<mvc:annotation-driven/>
标签写到springmvc-config.xml配置文件中,重新部署项目,问题成功解决。