自定义一个缓存类AdminCache
package jw.admin.common; import jw.base.entity.Admin;
import sun.security.util.Cache; public class AdminCache { //第一个参数表示cache对象中允许添加的键值对数量,第二个参数表示缓存的时间,单位是秒
private static Cache cache = Cache.newHardMemoryCache(0,3600 * 24 * 7); public static Admin get(String key){
return (Admin)cache.get(key);
}
public static void set(String key,Admin admin){
AdminCache.cache.put(key,admin);
} }
登陆成功发送Cookie到客户端并保存到缓存中
//如果选择记住登录状态,把用户签名保存到cookie中,把签名和签名的对象保存到缓存中
if (remember == true){
Cookie cookie = new Cookie("adminSign",admin.sign());
cookie.setMaxAge(60 * 60 * 24 * 7);
cookie.setPath("/");
response.addCookie(cookie);
AdminCache.set(admin.sign(),admin);
}
在spring-servlet中配置拦截器路径
<mvc:interceptors>
<!-- 使用bean定义一个Interceptor,直接定义在mvc:interceptors根下面的Interceptor将拦截所有的请求 -->
<bean class="jw.admin.interceptor.AuthInterceptor"/>
<bean class="jw.admin.interceptor.AuthCookieInterceptor"/>
</mvc:interceptors>
拦截器内容
package jw.admin.interceptor; import jw.admin.common.AdminCache;
import jw.base.entity.Admin;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession; public class AuthCookieInterceptor implements HandlerInterceptor { @Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
HttpSession session = request.getSession(); //判断session中的用户信息是否存在,不存在从cookie中获取然后装如session
if(session.getAttribute("admin") == null){
Cookie[] cookies = request.getCookies();
if(cookies != null && cookies.length > 0){
for(int i = 0; i < cookies.length; i++){
if(cookies[i].getName().equals("adminSign")){
String sign = cookies[i].getValue();
Admin admin = AdminCache.get(sign); //根据签名获取用户的完整信息装如session
session.setAttribute("admin",admin);
break;
}
}
}
}
return true;
} @Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } @Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { }
}