登录成功后7天无操做需再次登录

实现这种功能方法有不少,先后端均可以实现。本文将从后端(java)实现此功能。大概思路以下:java

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

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

//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;
    }
复制代码
相关文章
相关标签/搜索