欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

SSM登录拦截器Interceptor例子

程序员文章站 2022-07-09 17:03:03
...

这是一个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>
	
SSM登录拦截器Interceptor例子

SSM登录拦截器Interceptor例子