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 @   miku_moe  阅读(81)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示