Cookie原理(Java)

Cookie原理

  • http是无状态的传输协议,也就是说每一次和服务器交互都不会知道上一次交互做过什么,但是如果需要知道上次做过什么,保存过什么信息那么就需要使用cookie
  • 原理图
    在这里插入图片描述
  • 代码
@WebServlet("/cookie1")
// CookieDemo1
 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    Cookie c = new Cookie("msg", "hello-Cookie");
    response.addCookie(c);
  }
@WebServlet("/cookie2")
// CookieDemo2
  protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    Cookie[] cookies = request.getCookies();
    if (cookies != null) {
      for (Cookie c : cookies) {
        String key = c.getName();
        String value = c.getValue();
        System.out.println(key + " : " + value);
      }
    }
  }

  • 客户端访问/cookie1时服务端CookieDemo1会返回一个cookie也就是响应头里面添加有Set-Cookie: msg=hello-Cookie的字段,然后浏览的默认行为会将该字段保存在Applcation里的Cookie信息里面存储
    在这里插入图片描述
    在这里插入图片描述

  • 当访问/cookie2时浏览器会将所有的cookie作为请求头发送给服务端,这个时候CookieDemo2进行解析获取出每一个cookie从而知道上次浏览器http请求保存了什么数据(只要有cookie访问任何页面都会在请求头传入
    在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值