SpringMVC中的Interceptor拦截器,它的主要作用是拦截指定的用户需求,并进行相应的预处理与后处理。
其拦截的时间点在”处理器映射器根据用户提交的请求映射出了所要执行的处理器类,并且也找到哟啊执行该处理器类的处理器适配器,在处理器适配器执行处理器之前”。
在处理器映射器映射出所要执行的处理器类时,已经将拦截器与处理器组合为了一个处理器执行链,并返回给了中央调度器。
SpringMVC中的Interceptor拦截器
是针对请求和响应进行额外处理,在请求和响应的过程中添加预处理,后处理和最终处理。
拦截器执行的时机:
1:preHandle():在请求被处理之前进行操作
2:postHandle();在请求被处理之后,但结果还没有渲染前进行操作,可以改变响应结果
3:afterCompletion:所有的请求响应结束后执行善后工作,清理对象,关闭资源。
拦截器的实现方式
1、继承HandlerInterceptorAdapter的父类
2、实现HandlerInterceptorAdapter接口(推荐方式)
拦截器实现步骤
1、在session中存储用户信息,用于进行权限验证。
2、实现HandlerInterceptorAdapter接口,重写preHandle()方法
3、springMVC.xml文件中注册拦截器
1、在session中存储用户信息,用于进行权限验证。
//验证是否登录
@RequestMapping("userLogin")
public String login(String username, String password, HttpServletRequest request) {
UserDao mapper = sqlSessionAuto.getMapper(UserDao.class);
User admin = mapper.selectByName(username);
try {
if (admin.getUsername().equals(username) && admin.getPassword().equals(password)) {
int id = admin.getId();
//session中存储用户信息
request.getSession().setAttribute("id", id);
return "main";
} else {
request.setAttribute("msg", "用户名或密码错误!");
return "forward:/index.jsp";
}
} catch (Exception e) {
e.printStackTrace();
request.setAttribute("msg", "用户名或密码错误!");
return "forward:/index.jsp";
}
}
2、实现HandlerInterceptorAdapter接口,重写preHandle()方法
public class LoginInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
//判断是否登录过
if (request.getSession().getAttribute("id") == null){
request.setAttribute("msg","还未登录!");
request.getRequestDispatcher("/index.jsp").forward(request,response);
return false;
}else {
return true;//放行
}
}
}
3、springMVC.xml文件中注册拦截器
<!--注册拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<!--设置要拦截的请求 -->
<mvc:mapping path="/**"/>
<!--设置放行的请求-->
<mvc:exclude-mapping path="/userLogin"/>
<!--配置拦截器实现功能类-->
<bean class="com.controller.interceptor.LoginInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>