MIKU MOE

SSM_SpringMVC_拦截器

Spring_SSM


 

SpringMVC拦截器

SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。开发者可以自己定义一些拦截器来实现特定的功能。

 

过滤器与拦截器的区别: 拦截器是AOP思想的具体应用。

 

过滤器 Filter

  • servlet规范中的一部分,任何java web工程都可以使用

  • 在url-pattern中配置了/*之后,可以对所有要访问的资源进行拦截

 

拦截器 实现 HandlerInterceptor 接口

  • 拦截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能使用

  • 拦截器只会拦截访问的控制器方法,如果访问的是jsp/html/css/image/js是不会进行拦截的(相当于自动静态过滤)

 

 //过滤器在web.xml中配置
 //拦截器在spring核心配置文件配置
 <mvc:interceptors>
     <mvc:interceptor>
         <!--包括这个请求下面的所有的请求-->
         <mvc:mapping path="/**" />
         <bean class="com.study.config.MyInterceptor" />
     </mvc:interceptor>
 </mvc:interceptors>
 //=============================
 public class MyInterceptor implements HandlerInterceptor {
     public boolean preHandle(...){
         System.out.println("========处理前========");
         return true; //放行
     }
     /*
     public void postHandle(...){
         System.out.println("========处理后========"); //拦截日志
     }
     public void afterCompletion(...){
         System.out.println("========清理========"); //拦截日志
     }
     */
 }

 

案例

 @Controller
 @RequestMapping("/user")
 public class Logincontroller {
     @RequestMapping("/main")
     public String main(){ return "main"; }
     @RequestMapping("/goLogin")
     public String login(){ return "login"; }
     @RequestMapping("/login")
     public String login(HttpSession session,String username,String password){
         //把用户得信息存session中
         session.setAttribute("userLoginInfo",username);
         return "main";
     }
     //移除Session,注销
     @RequestMapping("/goOut")
     public string goout(Httpsession session){
         session.removeAttribute("userLoginInfo");
         return "main";
     }
 }
 //==============================
 public class LoginInterceptor implements HandlerInterceptor {
     public boolean preHandle(HttpServletRequest request,HttpServletResponse response,Object handler) throws Exception { 
         HttpSession session = request.getSession( );
         //登录页而也会放行
         if(request.getRequestURI().contains("goLogin")){
             return true;
         }
         //登录请求放行
         if(request.getRequestURI().contains("login")){
             return true;
         }
         //已经登陆放行
         if(session.getAttribute("userLoginInfo")!=null){
             return true;
         }  
         request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);
         return false;
     }
 }
 //==============================
 <mvc:interceptors>
     <mvc:interceptor>
         <mvc:mapping path="/user/**" />
         <bean class="com.study.config.LoginInterceptor" />
     </mvc:interceptor>
 </mvc:interceptors>

 

posted @ 2021-09-11 11:05  miku_moe  阅读(85)  评论(0)    收藏  举报