拦截器
什么是拦截器?
Spring MVC中的拦截器(Interceptor)类似于Servlet中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理。例如通过拦截器可以进行权限验证、判断用户是否登录等。
拦截器依赖于web框架,在实现上基于Java的反射机制,属于面向切面编程(AOP)的一种运用。
自定义拦截器
创建拦截器
package com.by.interceptor;import org.springframework.web.servlet.HandlerInterceptor;import org.springframework.web.servlet.ModelAndView;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;public class CustomHandlerInterceptor implements HandlerInterceptor {/** * 在控制器方法调用前执行 * 返回值为是否中断 *true:表示继续执行(下一个拦截器或处理器) *false:则会中断后续的所有操作,所以我们需要使用response来继续响应后续请求 */@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object object) throws Exception {System.out.println("HandlerInterceptor preHandle ....");return true; }/** * 在控制器方法调用后,解析视图前调用,我们可以对视图和模型做进一步渲染或修改 * 可在modelAndView中加入数据,比如当前时间 */@Overridepublic void postHandle(HttpServletRequest request,HttpServletResponse response,Object object, ModelAndView modelAndView) throws Exception {System.out.println("HandlerInterceptor postHandle ...."); }/** * 整个请求完成,即视图渲染结束后调用,这个时候可以做些资源清理工作,或日志记录 */@Overridepublic void afterCompletion(HttpServletRequest request,HttpServletResponse response,Object object, Exception e) throws Exception {System.out.println("HandlerInterceptor afterCompletion ...."); }}
配置拦截器
测试
编写controller
@Controller@RequestMapping("/account")public class AccountController {@RequestMapping("/findAccount12")public String findAccount12(Model model) {model.addAttribute("msg", "欢迎你 springmvc");System.out.println("controller的方法执行了......");return "success"; }}
在index.jsp里面定义超链接
拦截器
登录拦截器
创建拦截器
package com.by.interceptor;import org.springframework.web.servlet.HandlerInterceptor;import org.springframework.web.servlet.ModelAndView;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;public class LoginInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object object) throws Exception {String user = (String) request.getSession().getAttribute("user_session");if (user != null) {//已经登录,继续执行System.out.println("获得用户信息:"+user);return true; } else {//未登录,跳转到登录页面response.sendRedirect(request.getContextPath() +"/login.jsp");return false; } }}
配置拦截器
测试
编写controller
@Controller@RequestMapping("/account")public class AccountController {@RequestMapping("/findAccount13")public String findAccount13(Model model) {model.addAttribute("msg", "欢迎你 springmvc");System.out.println("controller的方法执行了......");return "success"; }}
在index.jsp里面定义超链接
登录拦截器