SSM登录拦截器Interceptor例子

这是一个SSM(Spring,SpringMVC,Mybatis)项目前台使用拦截器进行登录的例子,可实现指定页面(需要登录的页面)进行拦截,其他的页面不拦截,

方法的实现由两步:

1.写一个拦截器类

2.在spring-mvc.xml中配置拦截器(其它的xml好像也是可以的)

第一步:

 

package com.connie.interceptor;

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

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

import com.connie.entity.Citizen;

/**
 * 拦截器,用于拦截前台的登录
 * @author connie
 * 要在spring-mvc中配置拦截器<mvc:interceptor>
 *return false表示拦截,不向下执行
 *return true表示放行
 */
public class LoginInterceptor implements HandlerInterceptor  {
	
	
	 
	 
	//首先会执行的方法
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {
		
		  boolean flag = false;
		
		System.out.println("进入了preHandle。。。。。。");
		System.out.println("在这里进行判断是否程序继续进行,或者做其他的操作。。。。。。");
        System.out.println("getServletPath"+request.getServletPath());
   
		
		//从session中获取对象
		Citizen citizen = (Citizen) request.getSession().getAttribute("citizen");
		System.out.println("输出对象==========="+citizen);
		
		//获取请求资源
        String requestURI = request.getRequestURI();
        System.out.println("requestURI========="+requestURI);
        
        
        //我可以在这里写一个判断,分别拦截前后台的登录,路径包含
        
        //首先不拦截所有的登录和注册
        //判断是前台还是后台
        //后台所有的都拦截
        //前台不拦截指定的访问方法
        
         //指定前台要拦截的页面
         final String[] IGNORE_URI ={"login","/queryLogin","/toRegister","/getCode"};
         
         //不拦截的资源路径
         final String[] PRE_UNIGNORE_URI={
        		 "bookController/queryByCitizenId",
        		 "adviceController/queryAdvicePage",
        		 "affairsTypeController/queryAll",
        		 "adviceController/queryListByCitizenId"
         };
      
         //都不拦截的
         String uri = requestURI.substring(requestURI.lastIndexOf("/"));
         if(uri.startsWith("/login") || uri.startsWith("/queryLogin") || uri.startsWith("/toRegister")||uri.startsWith("/getCode")) {  
            System.out.println("请求uri是以特定的开头");
         	return true;  
         }
        
        //前台拦截
        //跳转指定资源而未登录的
    	for (String preURI : PRE_UNIGNORE_URI) {
    		 //设定前台需要拦截登录的相反结果集
            if(requestURI.contains(preURI)){
            	System.out.println("已拦截的页面******************"+preURI);
            	 flag =true;
            }
		}
    	if(flag){
    		 if(citizen==null){
    			 //重定向
    			 String loginUrl = "/project/loginMain.jsp"; 
    			 System.out.println("重定向========="+request.getContextPath() + loginUrl);
    			 response.sendRedirect(request.getContextPath() + loginUrl);
    			 System.out.println("重定向========="+request.getContextPath() + loginUrl);
       		
       		  return false;
       	  }
    	}
    	
    
		return true;
	}
	
	
	//返回ModelAndView之前执行的方法,面向切面编程中的体现,已经进入了controller
	public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
			throws Exception {
		System.out.println("进入了postHandle。。。。。。");
		
		
	}


	//执行Handle完成之后执行的方法
	public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
			throws Exception {

		System.out.println("进入了afterHandle。。。。。。");
	}
}

 

第二步:

 

	<!-- 配置登录验证拦截器 -->
	<mvc:interceptors>
		<bean class="com.connie.interceptor.LoginInterceptor"></bean>	
	</mvc:interceptors>
	

 

 

 

 

 

 

注:使用springboot时候配置拦截器

 

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值