实现这种功能方法有很多,前后端都可以实现。本文将从后端(java)实现此功能。大概思路如下:
- 登陆成功后,将当前系统时间+7天timeMillisDB(单位:毫秒)存到DB
- 在访问每个接口前校验登陆是否过期(使用拦截器进行统一校验)。校验规则:当前系统时间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;
}
欢迎访问我掘金的文章
作者:小码君
链接:https://juejin.im/post/5bed182ef265da61764a7452
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。