1. 程式人生 > 程式設計 >如何基於ssm框架實現springmvc攔截器

如何基於ssm框架實現springmvc攔截器

Springmvc攔截器用來攔截Controller層請求,可以在Controller方法執行前後做一些特定的業務邏輯處理。類似於AOP中的環繞通知。常用來做登入攔截,許可權控制等。

1)寫一個類,實現HandlerIntercept介面;

/**
 * 登入攔截器
 */
public class LoginInterceptor implements HandlerInterceptor {
  /**
   * 在控制層方法請求之前呼叫,返回一個boolean型別值
   * 如果返回的true則放行,如果返回false,則不繼續往後執行
   * @param request
   * @param response
   * @param handler
   * @return
   * @throws Exception
   */
  @Override
  public boolean preHandle(HttpServletRequest request,HttpServletResponse response,Object handler) throws Exception {
    String requestURI = request.getRequestURI();
    System.out.println("攔截到請求:"+requestURI);
    Admin admin = (Admin) request.getSession().getAttribute("admin");
    //如果admin為空,說明沒有登入
    if (admin==null){
      response.sendRedirect(request.getContextPath()+"/login.jsp");
      return false;//不繼續往後執行
    }
    return true;
  }

  /**
   * 在控制層方法執行返回之後執行,通常可以做一些全域性的資料返回等
   * @param request
   * @param response
   * @param handler
   * @param modelAndView 控制層方法返回的結果
   * @throws Exception
   */
  @Override
  public void postHandle(HttpServletRequest request,Object handler,ModelAndView modelAndView) throws Exception {
    System.out.println("進入攔截器postHandle方法");
    //ajax請求時,modelView為null
    if (modelAndView!=null){
    System.out.println("獲取到控制層方法返回結果:"+modelAndView.getModelMap()
            +"view:"+modelAndView.getViewName());
    }
  }

  /**
   * 檢視解析之後執行,通常用來做一些清理工作
   * @param request
   * @param response
   * @param handler
   * @param ex
   * @throws Exception
   */
  @Override
  public void afterCompletion(HttpServletRequest request,Exception ex) throws Exception {
    System.out.println("進入afterCompletion方法");
  }
}

2)在springmvc的配置檔案中配置攔截器(攔截的請求地址,放行的請求地址);

<!--  配置springmvc攔截器-->
  <mvc:interceptors>
    <mvc:interceptor>
      <!--      定義需要攔截的請求;/**:表示以/開頭的任意控制層請求;  /*:只能攔截一個/的請求-->
      <mvc:mapping path="/**"/>
      <!--      定義不攔截的請求-->
      <mvc:exclude-mapping path="/admin/login"/>
      <!--      配置攔截類-->
      <bean id="loginInterceptor" class="aop.LoginInterceptor"></bean>
    </mvc:interceptor>
  </mvc:interceptors>

3)在控制層方法中寫登入條件;

//在方法引數中定義HttpSession,HttpServletRequest,HttpServletResponse等物件,springmvc會自動注入該物件
  @RequestMapping("/login")
  public String login(String account,String password,HttpSession session){
    //根據使用者名稱查詢是否存在該使用者
    Admin admin = adminService.selectByAccount(account);
    if (admin!=null && admin.getPassword().equals(password)){
      //將使用者資訊放入session
      session.setAttribute("admin",admin);
      return "redirect:list";
    }
    return "/login.jsp";//以/開頭為絕對路徑,/對應webapp目錄
  }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。