Bladex后端实现登入时间过期后自动跳转登入页

背景现状

在这里插入图片描述
Bladex可手动设置过期时间,但是我使用的是springboot BladeX 2.8.1.RELEASE版本,存在session过期后,后端AuthUtil.getUser().getDetail()自动清空但前端却还可以继续访问页面,前端未跳转至登入页面,导致部分接口报错问题。
前端现状:判断所有返回R中如果存在code为401的结果值,清空前端用户数据后调用后端登出(/logout)接口成功,则退回登入页面(/login)

期待成果

后端:使用拦截器拦截所有业务接口,判断是否存在AuthUtil.getUser().getDetail()手动添加字段为null情况,如果为null,并返回状态401,前端自动跳转自登入页面

解决方法一

找到鉴权配置页面

在这里插入图片描述

重写拦截器addInterceptors

创建了一个名为 CustomMiddleware 的自定义中间件类,并将它注册到了 Blade 框架中。addPathPatterns() 方法用于指定需要被中间件处理的请求路径,excludePathPatterns() 方法用于指定不需要被中间件处理的请求路径。

	@Override
	public void addInterceptors(InterceptorRegistry registry) {
		registry.addInterceptor(new CustomMiddleware())
			.addPathPatterns("/**")
			.excludePathPatterns("/blade-auth/**")
			.excludePathPatterns("/blade-system/menu/routes")
			.excludePathPatterns("/blade-system/menu/auth-routes")
			.excludePathPatterns("/blade-system/menu/top-menu")
			.excludePathPatterns("/blade-system/tenant/info")
			.excludePathPatterns("/blade-flow/process/resource-view")
			.excludePathPatterns("/blade-flow/process/diagram-view")
			.excludePathPatterns("/blade-flow/manager/check-upload")
			.excludePathPatterns("/doc.html")
			.excludePathPatterns("/js/**")
			.excludePathPatterns("/webjars/**")
			.excludePathPatterns("/swagger-resources/**")
			.excludePathPatterns("/druid/**")
			.excludePathPatterns("/login");
	}

创建CustomMiddleware编制拦截逻辑

下面是一个 CustomMiddleware 类实现示例,其中假设您需要对所有请求进行用户登录认证,如果用户未登录则调用一个返回code为401的R实体类,前端接到401编码后自动返回登入页

public class CustomMiddleware implements HandlerInterceptor {

	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
		// 判断Session中的用户信息是否过期
		if(AuthUtil.getUser() == null || AuthUtil.getUser().getDetail() == null
			|| AuthUtil.getUser().getDetail().get("ancestors") == null){
			// 登录信息已过期,重定向到登录页面
			response.sendRedirect(request.getContextPath()+"/blade-auth/oauth/activeLogout");
			System.out.println(AuthUtil.getUser());
			System.out.println("--------------------------------------------");
			System.out.println(AuthUtil.getUser().getDetail());
			return false;
		}
		// 用户已登录,继续处理请求
		return true;
	}

}
	@GetMapping("/oauth/activeLogout")
	@ApiOperation(value = "主动退出登录")
	public R activeLogout() {
		BladeUser user = AuthUtil.getUser();
		if (user != null && jwtProperties.getState()) {
			String token = JwtUtil.getToken(WebUtil.getRequest().getHeader(TokenConstant.HEADER));
			JwtUtil.removeAccessToken(user.getTenantId(), String.valueOf(user.getUserId()), token);
		}
		return R.fail(401,"");
	}

实现了 HandlerInterceptor 接口,并实现了其中的 preHandle() 方法。preHandle() 方法会在请求到达控制器之前被调用,可以在这个方法中进行一些操作,例如用户认证、授权、日志记录等。在这个方法中,我们首先获取当前的 HttpSession 对象,判断用户是否已登录。如果用户未登录,则重定向到登录页面,并返回 false,表示请求已被处理完毕,不需要继续往下执行。如果用户已登录,则返回 true,表示请求可以继续处理。最后,我们可以在 BladeConfiguration 类的 addInterceptors() 方法中将 CustomMiddleware 注册到 Blade 框架中,让它对所有请求进行处理。

修改登入有效时常

blade:
  web:
    session:
      timeout: 180

server.servlet.session.timeout 是 Spring Boot 内置的参数,用于设置 servlet session 的超时时间。而 blade.web.session.timeout 是 Blade 框架的参数,用于设置 web session 的超时时间。因此,如果你在使用 Blade 框架的话,应该以 blade.web.session.timeout 为准。

需要注意的是,两个参数的时间单位不同,server.servlet.session.timeout 使用的是秒,而 blade.web.session.timeout 使用的是分钟。因此,在设置时间时需要根据实际情况进行转换
在这里插入图片描述
如果要修改登入时常,除了要设置后端session时常配置外,还需要设置令牌的时间

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值