SpringMVC,用户登录状态判断,统一拦截处理方法。(SpringBoot搭建项目)

0、登录时将用户信息放入session;退出登录时,清除session.

1、写一个拦截器LoginInterceptor,实现HandlerInterceptor(org.springframework.web.servlet.HandlerInterceptor)接口,重写preHandle方法,根据session判断是否登录。

由于是前后端分离,未登录时,后端代码无法直接重定向至前端,所以返回头部做一些设置,前端去判断并跳转。

//import省略
@Component
public class LoginInterceptor implements HandlerInterceptor {
    
	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
		//用Session提取userId来验证登陆
        HttpSession session = request.getSession();
        //userId,登陆时放入session的
        Long userId = (Long) session.getAttribute("userKey");
        //未登陆
        if (userId == null){
                //在返回头部设置标志
                response.addHeader("FLAG", "-1");
                response.setHeader("SESSIONSTATUS", "TIMEOUT");
                //重定向目标地址
                response.setHeader("CONTEXTPATH", "/");    
            //这个方法返回false表示忽略当前请求
            return false;
        }else {
        	//放行,用户即可继续调用自己需要的接口
            return true;    
        }
	}

	@Override
	public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
		// TODO Auto-generated method stub
		HandlerInterceptor.super.postHandle(request, response, handler, modelAndView);
	}

	@Override
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		// TODO Auto-generated method stub
		HandlerInterceptor.super.afterCompletion(request, response, handler, ex);
	}

}

2、写一个WebConfig,实现WebMvcConfigurer(org.springframework.web.servlet.config.annotation.WebMvcConfigurer),注册拦截器LoginInterceptor,重写addInterceptors即可。

//import省略
@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Autowired
    private LoginInterceptor loginInterceptor;

    /**静态资源处理*/
    @Override
	public void addResourceHandlers(ResourceHandlerRegistry registry) {
		WebMvcConfigurer.super.addResourceHandlers(registry);
	}
    
	/**注册自定义的拦截器loginInterceptor*/
	
	  @Override 
	  public void addInterceptors(InterceptorRegistry registry) {
	  registry.addInterceptor(loginInterceptor).addPathPatterns( 	      
         "/**"
	  ).excludePathPatterns( 
		  "/users/login", "/users/logout"
	  ); 
	  }
	 
}

3、前端如何判断是否登陆,并进行跳转?

//例如,一个fetch请求
       fetch('/api/user/getUser',{
           method:'get',
           headers: {      
           },
           credentials: 'include'
       }) 
         .then(this.handleResponse.bind(this))
         .then(res => {
            this.setState({total:res});        //更新state
      });


//handleResponse是一个函数,对fetch的返回进行处理

    //处理请求响应,看是否需要进行跳转
    handleResponse(response){
        { 
            //从头部获取字段
            let flag = response.headers.get("FLAG");
            let sessionStatus =  response.headers.get("SESSIONSTATUS");
            if(flag==="-1"&&sessionStatus==="TIMEOUT"){
                let url = response.headers.get("CONTEXTPATH");
                message.info("登录已失效,请重新登录!");
                window.location.href = url;      //跳转到这个地址
            }else{
               return response.json();    //否则,解析返回json数据
            }
        }
    }

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值