1. 程式人生 > 實用技巧 >SSM中的攔截器

SSM中的攔截器

SpringMVC的處理器攔截器類似於Servlet開發中的過濾器Filter,用於對處理器進行預處理和後處理。開發者可以自己定義一些攔截器來實現特定的功能。

過濾器與攔截器的區別:攔截器是AOP思想的具體應用。

過濾器

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

  • 在url-pattern中配置了/*之後,可以對所有要訪問的資源進行攔截

攔截器

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

  • 攔截器只會攔截訪問的控制器方法,如果訪問的是jsp/html/css/image/js是不會進行攔截

自定義攔截器

實現 HandlerInterceptor 介面。

  1. 新建一個Moudule

  2. 配置web.xml與 springmvc-servlet.xml檔案

  3. 編寫一個攔截器

public class MyInterceptor implements HandlerInterceptor {

    //在請求處理的方法之前執行
    //如果返回true執行下一個攔截器
    //如果返回false就不執行下一個攔截器
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println(
"處理前==============="); return true; } //在請求處理方法執行之後執行 public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } //在dispatcherServlet處理後執行,做清理工作 public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws
Exception { } }

4、spring中配置攔截器

<!--    攔截器配置-->
<mvc:interceptors>
    <mvc:interceptor>
<!--        /** 包括路勁及其子路徑-->
<!--        /admin/* 攔截的是/admin/add等等這種 , /admin/add/user不會被攔截-->

<!--        /admin/** 攔截的是/admin/下的所有-->
        <mvc:mapping path="/**"/>
<!--        bean配置的就是攔截器-->
        <bean class="com.guo.config.MyInterceptor"/>
    </mvc:interceptor>
</mvc:interceptors>

5、請求

@RestController
public class TestController {

    @RequestMapping("/t1")
    public String test(){
        System.out.println("執行了test()");
        return "success";
    }
}

實戰

1、自定義攔截器,繼承HandlerInterceptor

package com.guo.HandlerInterceptor;

import com.guo.pojo.User;
import org.springframework.web.servlet.HandlerAdapter;
import org.springframework.web.servlet.HandlerInterceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class handlerInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
    //通過session,拿到使用者登入資訊
        HttpSession session =request.getSession();
        User userSession =(User) session.getAttribute("USER_SESSION");
    //獲取角色屬性 Integer userRole
= userSession.getUserRole();
    //擷取請求片段 String requestURI
= request.getRequestURI(); if(userSession != null){ if(userRole==2){
        //對比擷取的請求片段中,是否存在"/provider"
if(requestURI.contains("/provider") || requestURI.contains("/bill")){ return true; }else { request.getRequestDispatcher("/jsp/error.jsp").forward(request,response); return false; } }else if(userRole==3){ if(requestURI.contains("/bill")){ return true; }else { request.getRequestDispatcher("/jsp/error.jsp").forward(request,response); return false; } }else{ return true; } }else { response.sendRedirect(request.getContextPath()+"/log/error"); return false; } } }

2、配置spring xml檔案

<!--    HandleInterceptor-->
    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/user/**"/>
            <mvc:mapping path="/provider/**"/>
            <mvc:mapping path="/bill/**"/>

            <bean class="com.guo.HandlerInterceptor.handlerInterceptor"/>
        </mvc:interceptor>
    </mvc:interceptors>

3、controller層

@Controller
@RequestMapping("/user")
public class UserController {}

@Controller
@RequestMapping("/provider")
public class ProviderController {}

@Controller
@RequestMapping("/bill")
public class BillController {}