91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于ssm框架實現springmvc攔截器的方法

發布時間:2020-07-01 15:00:25 來源:億速云 閱讀:196 作者:清晨 欄目:開發技術

這篇文章將為大家詳細講解有關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, HttpServletResponse response, 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, HttpServletResponse response, Object handler, 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目錄
  }

基于ssm框架實現springmvc攔截器的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

万州区| 湾仔区| 丹东市| 石台县| 库伦旗| 阳原县| 桓仁| 盱眙县| 同心县| 莱州市| 静海县| 临朐县| 肇源县| 南岸区| 仁怀市| 平罗县| 霍城县| 台中县| 双江| 祁连县| 霍州市| 民和| 沅江市| 淅川县| 淮滨县| 乌兰浩特市| 大丰市| 板桥市| 沅陵县| 农安县| 新晃| 蓝山县| 延边| 嵊州市| 离岛区| 尚志市| 建水县| 铜陵市| 雅安市| 伊金霍洛旗| 冕宁县|