Filter拦截器获取Bean
SSM框架中,Bean都是被Spring容器管理的,使用的时候,直接通过注解@Autowired,注入即可
在Filter中,不能使用@Autowired注解注入,通过注解获取到的为null
Filter并没有被Spring容器管理,它是运行在Tomcat上的,是由Servlet来管理的
Spring容器,只有都在容器中的两个对象,才可以使用注解获取
不在Spring容器中,不被Spring容器管理,根据就不会识别Spring的注解
通过Servlet上下文,来获取Java Bean
public class MessageFilter implements Filter {
private WebApplicationContext wac;
@Override
public void init(FilterConfig arg0) throws ServletException {
wac = (WebApplicationContext)arg0.getServletContext().getAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE);
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
try {
if (servletRequest!=null){
MessageController messageController = wac.getBean(MessageController.class);
servletRequest.setAttribute("messageList", messageController.selectMessageList());
}
} catch (Exception e) {
throw e;
} finally {
filterChain.doFilter(servletRequest, servletResponse);
}
}
@Override
public void destroy() {
}
}
在Filter的init方法中,通过WebApplicationContext
获取Servlet上下文ServletContext
在doFilter方法中,通过调用getBean方法,获取对应的Java Bean对象
注意
前置拦截器,如果,拦截的是所有的请求
必须,加try……catch,将chain.doFilter写到finally中
保证,无论拦截器的方法,执行成功还是失败,都会往下继续执行
否则,因为某个拦截器报错,请求中断,后台都无法继续执行
filterChain.doFilter(servletRequest, servletResponse);
Filter拦截器
属于前台拦截,可以拦截Http请求
AOP拦截器
属于后台拦截,可以拦截普通的参数,无法拦截Http请求
AOP拦截的参数类型
普通的参数可以拦截,基本类型的参数也可以拦截,普通的pojo对象,也可以拦截,但是,Model对象调用不到,无法拦截