Spring MVC - 拦截器实现 和 用户登陆例子

1.拦截器

  SpringMvc中的拦截器实现了HandlerInterceptor接口,通常使用与身份认证,授权和校验,模板视图,统一处理等;

   

public class HanderInterceptor1 implements HandlerInterceptor {

	@Override
	public void afterCompletion(HttpServletRequest arg0,
			HttpServletResponse arg1, Object arg2, Exception arg3)
			throws Exception {
	}

	@Override
	public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
			Object arg2, ModelAndView arg3) throws Exception {
	}

	@Override
	public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,
			Object arg2) throws Exception {
		return true;
	}
}

    在拦截器中中有三个方法 :

          preHandler :在进入Handler方法之前执行了,使用于身份认证,身份授权,登陆校验等,比如身份认证,用户没有登陆,拦截不再向下执行,返回值为 false ,即可实现拦截;否则,返回true时,拦截不进行执行;

          postHandler : 进入Handler方法之后,返回ModelAndView之前执行,使用场景从ModelAndView参数出发,比如,将公用的模型数据在这里传入到视图,也可以统一指定显示的视图等;

         afterHandler : 在执行Handler完成后执行此方法,使用于统一的异常处理,统一的日志处理等;


2.拦截器的配置

    拦截器的配置有两种方式实现 :

    (1)针对某个handlermapping (controller)的 配置 

             Springmvc拦截器针对某个controller进行拦截设置,如果在某个HandlerMapping中配置拦截,经过该HandlerMapping映射成功的handler最终使用该拦截器;

    

    (2)类似全局的配置

           可以配置类似全局的拦截器,springmvc框架将配置的类似全局拦截器注入到每个Handlermapping中;

      配置实现 :

    <!-- 配置拦截器 -->
	    <mvc:interceptors>
	        <!-- 多个拦截器,顺序执行 -->
	         <mvc:interceptor>
	           <!-- /** 表示所有的url,包括子url路径 -->
	             <mvc:mapping path="/**"/>
	             <bean class="cn.labelnet.ssm.filter.HanderInterceptor1"></bean>
	         </mvc:interceptor>
	         <!-- 配置登陆拦截器 -->
	         <mvc:interceptor>
	             <mvc:mapping path="/**"/>
	             <bean class="cn.labelnet.ssm.filter.LoginHandlerIntercepter"></bean>
	         </mvc:interceptor>
	         <!-- 
	         .....
	         
	          -->
	    </mvc:interceptors>



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

             多个拦截器使用的时候,preHandler是顺序执行的,而postHandler和afterHandler是倒序执行的;

        所以 :

         如果统一日志处理器拦截器,需要改拦截器prehandler一定要返回true,且将它放在拦截器配置的第一个位置;

         如果登陆认证拦截器,放在拦截器的配置中的第一个位置(有日志处理的话,放在日志处理下面);

          如果有权限校验拦截器,则放在登陆拦截器之后,因为登陆通过后,才可以进行校验权限;


 3.示例:

     场景描述 :用户点击查看的时候,我们进行登陆拦截器操作,判断用户是否登陆? 登陆,则不拦截,没登陆,则转到登陆界面;

     图示 :

                     

    3.1 controller 登陆业务实现

	@RequestMapping("/clientLogin")
	public String clientLogin(HttpSession httpSession,String username,String password){
		
		if(username.equals("yuan")&&password.equals("123456")){
			//登陆成功
			httpSession.setAttribute("username",username);
			return "forward:clientsList.action";
		}else{
			//登陆失败
			return "forward:login.jsp";
		}
	}

   3.2 controller 登出业务实现 

@RequestMapping("/clientLoginOut")
	public String clientLoginOut(HttpSession httpSession){
		httpSession.invalidate();
		return "forward:clientsList.action";
	}
	
 

  3.3 拦截器实现

        在这里实现用户拦截实现是:通过判断是否是编辑查看的页面,如果是,判断session中的用户名存在不存在,就可以了;

package cn.labelnet.ssm.filter;

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

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

/**
 * 登陆拦截器
 * 场景:用户点击查看的时候,我们进行登陆拦截器操作,判断用户是否登陆?
 * 登陆,则不拦截,没登陆,则转到登陆界面;
 * TODO
 * 作者:原明卓
 * 时间:2016年1月8日 下午3:25:35
 * 工程:SpringMvcMybatis1Demo
 */
public class LoginHandlerIntercepter implements HandlerInterceptor {
	
	@Override
	public void afterCompletion(HttpServletRequest request,
			HttpServletResponse response, Object arg2, Exception arg3)
			throws Exception {
	}

	@Override
	public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
			Object arg2, ModelAndView arg3) throws Exception {

	}
	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse arg1,
			Object arg2) throws Exception {
	       String requestURI = request.getRequestURI();
	         if(requestURI.indexOf("editClientIfo.action")>0){
	        	 //说明处在编辑的页面
	        	 HttpSession session = request.getSession();
	        	 String username = (String) session.getAttribute("username");
	        	 if(username!=null){
	        		 //登陆成功的用户
	        		 return true;
	        	 }else{
	        		//没有登陆,转向登陆界面
	    	         request.getRequestDispatcher("/login.jsp").forward(request,arg1);
	    		   return false;
	        	 }
	         }else{
	        	 return true;
	         }
	}

}

   3.4 拦截器配置实现

    <!-- 配置拦截器 -->
	    <mvc:interceptors>
	        <!-- 多个拦截器,顺序执行 -->
	         <mvc:interceptor>
	           <!-- /** 表示所有的url,包括子url路径 -->
	             <mvc:mapping path="/**"/>
	             <bean class="cn.labelnet.ssm.filter.HanderInterceptor1"></bean>
	         </mvc:interceptor>
	         <!-- 配置登陆拦截器 -->
	         <mvc:interceptor>
	             <mvc:mapping path="/**"/>
	             <bean class="cn.labelnet.ssm.filter.LoginHandlerIntercepter"></bean>
	         </mvc:interceptor>
	         <!-- 
	         .....
	         
	          -->
	    </mvc:interceptors>
	    


  3.5 登陆页面实现

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>用户登陆</title>
    
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->

  </head>
  
  <body>
      
      <form action="${pageContext.request.contextPath }/clients/clientLogin.action" method="post">
         姓名:<input type="text" name="username"> <br><br>
         密码:   <input type="text" name="password"> <br><br>
         <input type="submit" value="登陆">
      </form>
      
  </body>
</html>

   3.6 列表信息页面

<body>
       <h1>客户信息管理 <br>
       
      <c:if test="${username!=null }">
          ${username}
          <a href="${pageContext.request.contextPath}/clients/clientLoginOut.action">退出</a>
      </c:if>
      </h1>
      <form method="post"  action=""  style="margin-top: 10px;float: left;margin-left: 5%;">
        <input id="search"  type="text" >
        <input  value="查询" type="submit">
      </form>
      <table width="90%" border="1" align="center">
         <thead>
                     <tr>
                           <td colspan="10"  align="center">  客户信息管理</td>
                     </tr>      
         </thead>
         <tbody>
            <tr align="center">
                <td>编号</td>
                <td>姓名</td>
                <td>代码</td>
                <td>生日</td>
                <td>家庭住址</td>
                <td>现居住地</td>
                <td>联系方式</td>
                <td>紧急联系方式</td>
                <td>注册日期</td>
                <td>操作</td>
            </tr>
            <c:forEach items="${clients}" var="c">
            
              <tr>
                <td>  ${c.id}  </td>
                <td> ${c.username} </td>
                <td> ${c.client_certificate_no} </td>
                <td> ${c.born_date} </td>
                <td> ${c.family_register_address} </td>
                <td> ${c.now_address} </td>
                <td> ${c.contact_mode} </td>
                <td> ${c.urgency_contact_mode} </td>
                <td> ${c.create_date} </td>
                <td><a href="${pageContext.request.contextPath}/clients/editClientIfo.action?id=${c.id}">查看</a></td>
            </tr>
            
            </c:forEach>
         </tbody>
      </table>
  </body>


4.Demo免积分下载

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


  • 21
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 17
    评论
Spring MVC 中,拦截器实现确实可以使用反射机制。一个典型的例子是在拦截器中获取方法的参数信息。 假设我们有一个自定义的拦截器 `CustomInterceptor`,我们希望在方法调用前后打印方法的参数信息。 ```java public class CustomInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { if (handler instanceof HandlerMethod) { HandlerMethod handlerMethod = (HandlerMethod) handler; Method method = handlerMethod.getMethod(); // 使用反射获取方法的参数信息 Parameter[] parameters = method.getParameters(); for (Parameter parameter : parameters) { System.out.println("Parameter: " + parameter.getName() + ", Type: " + parameter.getType()); } } return true; } // 其他方法省略... } ``` 在上面的例子中,我们在 `preHandle` 方法中通过反射获取了方法的参数信息。`handler` 参数是被拦截的处理器方法,通过判断它是否为 `HandlerMethod` 类型,我们可以确保它是一个带有具体方法的处理器。 然后,我们使用 `HandlerMethod` 对象获取具体的方法对象,并通过反射获取该方法的参数信息。在这个例子中,我们简单地打印了参数的名称和类型,但实际上可以根据需求对参数进行进一步处理。 需要注意的是,虽然这个例子展示了拦截器使用反射获取方法参数信息的方式,但并不代表所有的拦截器都必须使用反射。拦截器的具体实现方式可以根据开发者的需求和偏好来选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值