浏览器数据存储:Cookie和Session,localStorage 和 sessionStorage

Cookie是value-key键值对,一个Cookie中只能有一个键值对。

从HttpServletRequest中获取Cookie,向HttpServletResponse中添加Cookie:

protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        resp.setContentType("text/html;charset=utf-8");
        //从HttpServletRequest中获取Cookie
        Cookie[] cookies = req.getCookies();
        Cookie findCookie = null;
        if (cookies != null) {
            for (Cookie cs : cookies) {
                if ("firstCookie".equals(cs.getName())) {
                    findCookie = cs;
                }
            }
        }
        if (findCookie == null) {
            //第一次访问时,设置cookie
            resp.getWriter().println("welcome !!");
            LocalDateTime localDateTime = LocalDateTime.now();
            Cookie cookie = new Cookie("firstCookie", localDateTime.toString());
            //设置Cookie存活时间
            cookie.setMaxAge(7 * 24 * 60 * 60);
            resp.addCookie(cookie);
        }else {
            //读取Cookie
            resp.getWriter().println("pre visit time:");
            resp.getWriter().println(findCookie.getValue());
            findCookie.setValue(LocalDateTime.now().toString());
            //向HttpServletResponse中添加Cookie
            resp.addCookie(findCookie);
        }
    }

 

设置Session,Session的本质也是一种Cookie:

    // 获取session对象
        HttpSession session = req.getSession();
        // 获取session的Id,id相对于用户+浏览器独一无二
        session.getId();
        // 通过session传递参数key-value键值对
        session.setAttribute(name, value);
        session.getAttribute(name);
        // 设置session存活时间,以秒计
        session.setMaxInactiveInterval(interval);
        // 清除全部键值对
        session.invalidate();

 

html5中的数据存储:

localStorage - 没有时间限制的数据存储,数据存储在浏览器中,关闭当前页面或浏览器数据也不会丢失。

<!DOCTYPE HTML>
<html>
<body>

<script type="text/javascript">

if (localStorage.pagecount)
    {
    localStorage.pagecount=Number(localStorage.pagecount) +1;
    }
else
    {
    localStorage.pagecount=1;
    }
document.write("Visits: " + localStorage.pagecount + " time(s).");

</script> 

<p>刷新页面会看到计数器在增长。</p>

<p>请关闭浏览器窗口,然后再试一次,计数器会继续计数。</p>

</body>
</html>

 

sessionStorage 方法针对一个 session 进行数据存储。当用户关闭浏览器窗口后,数据会被删除:

<!DOCTYPE HTML>
<html>
<body>

<script type="text/javascript">

if (sessionStorage.pagecount)
    {
    sessionStorage.pagecount=Number(sessionStorage.pagecount) +1;
    }
else
    {
    sessionStorage.pagecount=1;
    }
document.write("Visits " + sessionStorage.pagecount + " time(s) this session.");

</script> 

<p>刷新页面会看到计数器在增长。</p>

<p>请关闭浏览器窗口,然后再试一次,计数器已经重置了。</p>

</body>
</html>

 

转载于:https://www.cnblogs.com/mada0/p/4789178.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值