JS Bin

CookieUtil工具类

  主要是用于后期的代码扩展,在业务中的思路:服务器背景是有一个tomcat集群,为了实现单点登录的功能,将登录的请求打到了其中一台服务器上面,将此会话session的id以token的形式传入,并封装到cookie中放回响应response中去。并将用户的登录信息放到分布式缓存中,key就为此Session的id,CookieUtil工具类主要包含重新组装cookie,从请求中读取cookie,往响应中写cookie,删除指定的cookie。

  CookieUtil类:

/**
 * @author 大神爱吃茶
 * @Date 2020/1/6 0006 下午 20:04
 */
public class CookieUtil {
    private static Logger logger = LoggerFactory.getLogger(CookieUtil.class);

    private final static String COOKIE_DOMAIN = ".rmall.com";
    private final static String COOKIE_NAME = "rmall_login_token";

    //从请求中读取cookie
    public static String readLoginToken(HttpServletRequest request){
        Cookie[] cks = request.getCookies();
        if(cks != null){
            for(Cookie ck : cks){
                logger.info("read cookieName:{},cookieValue:{}",ck.getName(),ck.getValue());
                if(StringUtils.equals(ck.getName(), COOKIE_NAME)){
                    logger.info("return cookieName:{},cookieValue:{}",ck.getName(),ck.getValue());
                    return ck.getValue();
                }
            }
        }
        return null;
    }

    //往响应中写cookie
    public static void writeLoginToken(HttpServletResponse response,String token){//这里的cookie的名字就是rmall_login_token,而值就是token,这里的token就是sessionID
        Cookie cookie = new Cookie(COOKIE_NAME, token);
        cookie.setDomain(COOKIE_DOMAIN);
        //将cookie设置在根目录下面
        cookie.setPath("/");
        cookie.setHttpOnly(true);
        //设置cookie的有效期,单位是秒(一年)
        //如果这个maxage不设置的话,cookie就不会写入硬盘,而是写在内存。只在当前页面有效。
        cookie.setMaxAge(60*60*24*365);
        logger.info("write cookieName:{},cookieValue:{}",cookie.getName(),cookie.getValue());
        response.addCookie(cookie);
    }

    //删除cookie(从请求中读,往响应中写,已经删除完了的)
    public static void delLoginToken(HttpServletRequest request,HttpServletResponse response){
        Cookie[] cookies = request.getCookies();
        if(cookies != null){
            for(Cookie cookie : cookies){
                if(StringUtils.equals(cookie.getName(), COOKIE_NAME)){
                    cookie.setDomain(COOKIE_DOMAIN);
                    cookie.setPath("/");
                    cookie.setMaxAge(0);
                    logger.info("del cookieName:{},cookieValue:{}",cookie.getName(),cookie.getValue());
                    response.addCookie(cookie);
                    return;
                }
            }
        }
    }

}
posted @ 2020-01-07 16:21  左五六  阅读(2683)  评论(0编辑  收藏  举报