• 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;
                    }
                }
            }
        }
    
    }
  • 相关阅读:
    Struts2结合Ajax实现登录
    Java读取Properties文件
    职责链模式
    javaScript初学者易错点
    2019 DevOps 必备面试题——DevOps 理念篇
    如何成为一名优秀的敏捷团队负责人
    为什么企业敏捷团队会失败
    伪装的敏捷,我好累
    CODING 告诉你如何建立一个 Scrum 团队
    十倍程序员的传说
  • 原文地址:https://www.cnblogs.com/dashenaichicha/p/12162200.html
Copyright © 2020-2023  润新知