登陆成功后7天无操作需再次登陆

561 阅读1分钟

实现这种功能方法有很多,前后端都可以实现。本文将从后端(java)实现此功能。大概思路如下:

  1. 登陆成功后,将当前系统时间+7天timeMillisDB(单位:毫秒)存到DB
  2. 在访问每个接口前校验登陆是否过期(使用拦截器进行统一校验)。校验规则:当前系统时间currentTimeMillis-timeMillisDB > 0 ,则过期,返回登录页;否则,更新系统过期时间(当前系统时间+7天timeMillisDB)
如果考虑到性能可将过期时间存至Redis,而且实现起来较简单。

拦截器注入service为空,可进行拦截器配置:

//spring boot 拦截器配置
@Configuration
public class ServletContextConfig extends WebMvcConfigurerAdapter {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(loginInterceptor())
                .excludePathPatterns("/error", "/test/error") // 排除拦截
                .addPathPatterns("/**"); //对全路径请求进行拦截
        super.addInterceptors(registry);
    }

    // 处理业务的类
    @Bean
    public LoginInterceptor loginInterceptor(){
        return new LoginInterceptor();
    }

}

public class LoginInterceptor implements HandlerInterceptor {
    private static final Logger logger = LoggerFactory.getLogger(LoginInterceptor.class);

    @Autowired
    private XXXService xxxService;// 此时Service会注入成功

    public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
        // 业务处理
        return true;
    }