어떻게 ssm 프레임 워 크 를 바탕 으로 springmvc 차단 기 를 실현 합 니까?

Springmvc 차단 기 는 Controller 층 의 요청 을 차단 하 는 데 사용 되 며,Controller 방법 이 실 행 된 전후 에 특정한 업무 논리 처 리 를 할 수 있 습 니 다.AOP 의 서 라운드 알림 과 유사 합 니 다.로그 인 차단,권한 제어 등에 자주 사용 된다.
1)클래스 를 작성 하여 Handler Intercept 인 터 페 이 스 를 실현 합 니 다.

/**
 *      
 */
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  
  }
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기