shiro的rememberMe没有生效
我擦,忘了让我的user实现序列化接口了,实现后,测试正常。
其实也应该想到的,shiro有很多log.debug所以最好开启debug日志
默认保留时长是1年,所以修改,设置属性 即可
通过走源码的方式
找到DefaultSecurityManager
public class DefaultSecurityManager extends SessionsSecurityManager {
public Subject login(Subject subject, AuthenticationToken token) throws AuthenticationException {
AuthenticationInfo info;
try {
info = authenticate(token);
} catch (AuthenticationException ae) {
try {
onFailedLogin(token, ae, subject);
} catch (Exception e) {
}
throw ae; //propagate
}
Subject loggedIn = createSubject(token, info, subject);
onSuccessfulLogin(token, info, loggedIn);
return loggedIn;
}
protected void onSuccessfulLogin(
AuthenticationToken token, AuthenticationInfo info, Subject subject) {
rememberMeSuccessfulLogin(token, info, subject);
}
protected void rememberMeSuccessfulLogin(AuthenticationToken token, AuthenticationInfo info, Subject subject) {
RememberMeManager rmm = getRememberMeManager(); // 获取remememberMeManager
if (rmm != null) {
rmm.onSuccessfulLogin(subject, token, info); // 此处调用 记住我的方法 ,依此进入源码即可
}
}
}