Spring MVC - 攔截器實現 和 用戶登陸例子


1.攔截器

  SpringMvc中的攔截器實現了HandlerInterceptor接口,通常使用與身份認證,授權和校驗,模板視圖,統一處理等;

   

[java] view plain copy
 
  1. public class HanderInterceptor1 implements HandlerInterceptor {  
  2.   
  3.     @Override  
  4.     public void afterCompletion(HttpServletRequest arg0,  
  5.             HttpServletResponse arg1, Object arg2, Exception arg3)  
  6.             throws Exception {  
  7.     }  
  8.   
  9.     @Override  
  10.     public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,  
  11.             Object arg2, ModelAndView arg3) throws Exception {  
  12.     }  
  13.   
  14.     @Override  
  15.     public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,  
  16.             Object arg2) throws Exception {  
  17.         return true;  
  18.     }  
  19. }  

 

 

    在攔截器中中有三個方法 :

          preHandler :在進入Handler方法之前執行了,使用於身份認證,身份授權,登陸校驗等,比如身份認證,用戶沒有登陸,攔截不再向下執行,返回值為 false ,即可實現攔截;否則,返回true時,攔截不進行執行;

          postHandler : 進入Handler方法之后,返回ModelAndView之前執行,使用場景從ModelAndView參數出發,比如,將公用的模型數據在這里傳入到視圖,也可以統一指定顯示的視圖等;

         afterHandler : 在執行Handler完成后執行此方法,使用於統一的異常處理,統一的日志處理等;

 

2.攔截器的配置

    攔截器的配置有兩種方式實現 :

    (1)針對某個handlermapping (controller)的 配置 

             Springmvc攔截器針對某個controller進行攔截設置,如果在某個HandlerMapping中配置攔截,經過該HandlerMapping映射成功的handler最終使用該攔截器;

    

    (2)類似全局的配置

           可以配置類似全局的攔截器,springmvc框架將配置的類似全局攔截器注入到每個Handlermapping中;

      配置實現 :

 

[html] view plain copy
 
  1. <!-- 配置攔截器 -->  
  2.  <mvc:interceptors>  
  3.      <!-- 多個攔截器,順序執行 -->  
  4.       <mvc:interceptor>  
  5.         <!-- /** 表示所有的url,包括子url路徑 -->  
  6.           <mvc:mapping path="/**"/>  
  7.           <bean class="cn.labelnet.ssm.filter.HanderInterceptor1"></bean>  
  8.       </mvc:interceptor>  
  9.       <!-- 配置登陸攔截器 -->  
  10.       <mvc:interceptor>  
  11.           <mvc:mapping path="/**"/>  
  12.           <bean class="cn.labelnet.ssm.filter.LoginHandlerIntercepter"></bean>  
  13.       </mvc:interceptor>  
  14.       <!--  
  15.       ..... 
  16.        
  17.        -->  
  18.  </mvc:interceptors>  



 

 

     (3)在一個工程中,可以配置多個攔截器,使用多個攔截器,則要注意的是 :

             多個攔截器使用的時候,preHandler是順序執行的,而postHandler和afterHandler是倒序執行的;

        所以 :

         如果統一日志處理器攔截器,需要改攔截器prehandler一定要返回true,且將它放在攔截器配置的第一個位置;

         如果登陸認證攔截器,放在攔截器的配置中的第一個位置(有日志處理的話,放在日志處理下面);

          如果有權限校驗攔截器,則放在登陸攔截器之后,因為登陸通過后,才可以進行校驗權限;

 

 3.示例:

     場景描述 :用戶點擊查看的時候,我們進行登陸攔截器操作,判斷用戶是否登陸? 登陸,則不攔截,沒登陸,則轉到登陸界面;

     圖示 :

                     

    3.1 controller 登陸業務實現

 

[java] view plain copy
 
  1. @RequestMapping("/clientLogin")  
  2. public String clientLogin(HttpSession httpSession,String username,String password){  
  3.       
  4.     if(username.equals("yuan")&&password.equals("123456")){  
  5.         //登陸成功  
  6.         httpSession.setAttribute("username",username);  
  7.         return "forward:clientsList.action";  
  8.     }else{  
  9.         //登陸失敗  
  10.         return "forward:login.jsp";  
  11.     }  
  12. }  


   3.2 controller 登出業務實現 

 

 

[java] view plain copy
 
  1. @RequestMapping("/clientLoginOut")  
  2.     public String clientLoginOut(HttpSession httpSession){  
  3.         httpSession.invalidate();  
  4.         return "forward:clientsList.action";  
  5.     }  
  6.       

 

 

  3.3 攔截器實現

        在這里實現用戶攔截實現是:通過判斷是否是編輯查看的頁面,如果是,判斷session中的用戶名存在不存在,就可以了;

 

[java] view plain copy
 
  1. package cn.labelnet.ssm.filter;  
  2.   
  3. import javax.servlet.http.HttpServletRequest;  
  4. import javax.servlet.http.HttpServletResponse;  
  5. import javax.servlet.http.HttpSession;  
  6.   
  7. import org.springframework.web.servlet.HandlerInterceptor;  
  8. import org.springframework.web.servlet.ModelAndView;  
  9.   
  10. /** 
  11.  * 登陸攔截器 
  12.  * 場景:用戶點擊查看的時候,我們進行登陸攔截器操作,判斷用戶是否登陸? 
  13.  * 登陸,則不攔截,沒登陸,則轉到登陸界面; 
  14.  * TODO 
  15.  * 作者:原明卓 
  16.  * 時間:2016年1月8日 下午3:25:35 
  17.  * 工程:SpringMvcMybatis1Demo 
  18.  */  
  19. public class LoginHandlerIntercepter implements HandlerInterceptor {  
  20.       
  21.     @Override  
  22.     public void afterCompletion(HttpServletRequest request,  
  23.             HttpServletResponse response, Object arg2, Exception arg3)  
  24.             throws Exception {  
  25.     }  
  26.   
  27.     @Override  
  28.     public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,  
  29.             Object arg2, ModelAndView arg3) throws Exception {  
  30.   
  31.     }  
  32.     @Override  
  33.     public boolean preHandle(HttpServletRequest request, HttpServletResponse arg1,  
  34.             Object arg2) throws Exception {  
  35.            String requestURI = request.getRequestURI();  
  36.              if(requestURI.indexOf("editClientIfo.action")>0){  
  37.                  //說明處在編輯的頁面  
  38.                  HttpSession session = request.getSession();  
  39.                  String username = (String) session.getAttribute("username");  
  40.                  if(username!=null){  
  41.                      //登陸成功的用戶  
  42.                      return true;  
  43.                  }else{  
  44.                     //沒有登陸,轉向登陸界面  
  45.                      request.getRequestDispatcher("/login.jsp").forward(request,arg1);  
  46.                    return false;  
  47.                  }  
  48.              }else{  
  49.                  return true;  
  50.              }  
  51.     }  
  52.   
  53. }  


   3.4 攔截器配置實現

 

 

[html] view plain copy
 
  1. <!-- 配置攔截器 -->  
  2.  <mvc:interceptors>  
  3.      <!-- 多個攔截器,順序執行 -->  
  4.       <mvc:interceptor>  
  5.         <!-- /** 表示所有的url,包括子url路徑 -->  
  6.           <mvc:mapping path="/**"/>  
  7.           <bean class="cn.labelnet.ssm.filter.HanderInterceptor1"></bean>  
  8.       </mvc:interceptor>  
  9.       <!-- 配置登陸攔截器 -->  
  10.       <mvc:interceptor>  
  11.           <mvc:mapping path="/**"/>  
  12.           <bean class="cn.labelnet.ssm.filter.LoginHandlerIntercepter"></bean>  
  13.       </mvc:interceptor>  
  14.       <!--  
  15.       ..... 
  16.        
  17.        -->  
  18.  </mvc:interceptors>  
  19.    



  3.5 登陸頁面實現

 

 

[html] view plain copy
 
  1. <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>  
  2. <%  
  3. String path = request.getContextPath();  
  4. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";  
  5. %>  
  6.   
  7. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
  8. <html>  
  9.   <head>  
  10.     <base href="<%=basePath%>">  
  11.       
  12.     <title>用戶登陸</title>  
  13.       
  14.     <meta http-equiv="pragma" content="no-cache">  
  15.     <meta http-equiv="cache-control" content="no-cache">  
  16.     <meta http-equiv="expires" content="0">      
  17.     <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">  
  18.     <meta http-equiv="description" content="This is my page">  
  19.     <!-- 
  20.     <link rel="stylesheet" type="text/css" href="styles.css"> 
  21.     -->  
  22.   
  23.   </head>  
  24.     
  25.   <body>  
  26.         
  27.       <form action="${pageContext.request.contextPath }/clients/clientLogin.action" method="post">  
  28.          姓名:<input type="text" name="username"<br><br>  
  29.          密碼:   <input type="text" name="password"<br><br>  
  30.          <input type="submit" value="登陸">  
  31.       </form>  
  32.         
  33.   </body>  
  34. </html>  


   3.6 列表信息頁面

 

 

[html] view plain copy
 
  1. <body>  
  2.        <h1>客戶信息管理 <br>  
  3.          
  4.       <c:if test="${username!=null }">  
  5.           ${username}  
  6.           <href="${pageContext.request.contextPath}/clients/clientLoginOut.action">退出</a>  
  7.       </c:if>  
  8.       </h1>  
  9.       <form method="post"  action=""  style="margin-top: 10px;float: left;margin-left: 5%;">  
  10.         <input id="search"  type="text" >  
  11.         <input  value="查詢" type="submit">  
  12.       </form>  
  13.       <table width="90%" border="1" align="center">  
  14.          <thead>  
  15.                      <tr>  
  16.                            <td colspan="10"  align="center">  客戶信息管理</td>  
  17.                      </tr>        
  18.          </thead>  
  19.          <tbody>  
  20.             <tr align="center">  
  21.                 <td>編號</td>  
  22.                 <td>姓名</td>  
  23.                 <td>代碼</td>  
  24.                 <td>生日</td>  
  25.                 <td>家庭住址</td>  
  26.                 <td>現居住地</td>  
  27.                 <td>聯系方式</td>  
  28.                 <td>緊急聯系方式</td>  
  29.                 <td>注冊日期</td>  
  30.                 <td>操作</td>  
  31.             </tr>  
  32.             <c:forEach items="${clients}" var="c">  
  33.               
  34.               <tr>  
  35.                 <td>  ${c.id}  </td>  
  36.                 <td> ${c.username} </td>  
  37.                 <td> ${c.client_certificate_no} </td>  
  38.                 <td> ${c.born_date} </td>  
  39.                 <td> ${c.family_register_address} </td>  
  40.                 <td> ${c.now_address} </td>  
  41.                 <td> ${c.contact_mode} </td>  
  42.                 <td> ${c.urgency_contact_mode} </td>  
  43.                 <td> ${c.create_date} </td>  
  44.                 <td><href="${pageContext.request.contextPath}/clients/editClientIfo.action?id=${c.id}">查看</a></td>  
  45.             </tr>  
  46.               
  47.             </c:forEach>  
  48.          </tbody>  
  49.       </table>  
  50.   </body>  



 

4.Demo免積分下載

http://download.csdn.net/detail/lablenet/9396235


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM