Cookie是什么

cookie的中文翻译是曲奇,小甜饼的意思。cookie其实就是一些数据信息,类型为“小型文本文件”,存储于电脑上的文本文件中。


Cookie有什么用

我们想象一个场景,当我们打开一个网站时,如果这个网站我们曾经登录过,那么当我们再次打开网站时,发现就不需要再次登录了,而是直接进入了首页。例如bilibili,csdn等网站。

这是怎么做到的呢?其实就是游览器保存了我们的cookie,里面记录了一些信息,当然,这些cookie是服务器创建后返回给游览器的。游览器只进行了保存。下面展示bilibili网站保存的cookie。


Cookie的表示

一般情况下,cookie是以键值对进行表示的(key-value),例如name=jack,这个就表示cookie的名字是name,cookie携带的值是jack。


Cookie的组成

下面我自己写了一个简易Servlet来设置cookie,我们游览器抓包进行查看。然后进行分析

以下是cookie中常用属性的解释。

  • Name:这个是cookie的名字
  • Value:这个是cooke的值
  • Path:这个定义了Web站点上可以访问该Cookie的目录
  • Expires:这个值表示cookie的过期时间,也就是有效值,cookie在这个值之前都有效。
  • Size:这个表示cookie的大小

想要完全了解所有cookie属性,请参考百度知道:cookie


Cookie的HTTP传输

我们还是通过抓包进行查看。首先查看cookie在HTTP请求中是怎样进行表示的。

HTTP请求

我们在发送HTTP请求时,发现游览器将我们的cookie都进行了携带(注意:游览器只会携带在当前请求的url中包含了该cookie中path值的cookie),并且是以key:value的形式进行表示的。多个cookie用;进行隔开。

我们再来查看cookie在HTTP响应中是如何进行表示的。

HTTP响应

我在服务器设置了2个cookie,返回给游览器。通过抓包,我们发现在HTTP响应中, cookie的表示形式是,Set-Cookie:cookie的名字,cookie的值。如果有多个cookie,那么在HTTP响应中就使用多个Set-Cookie进行表示。


Cookie的生命周期

cookie有2种存储方式,一种是会话性,一种是持久性。

  • 会话性:如果cookie为会话性,那么cookie仅会保存在客户端的内存中,当我们关闭客服端时cookie也就失效了
  • 持久性:如果cookie为持久性,那么cookie会保存在用户的硬盘中,直至生存期结束或者用户主动将其销毁。

cookie我们是可以进行设置的,我们可以人为设置cookie的有效时间,什么时候创建,什么时候销毁。


Cookie使用的常见方法

下面,我对java中Cookie对象的方法进行讲解

  • new Cookie(String name, String value):创建一个Cookie对象,必须传入cookie的名字和cookie的值
  • getValue():得到cookie保存的值
  • getName():获取cookie的名字
  • setMaxAge(int expiry):设置cookie的有效期,默认为-1。这个如果设置负数,表示客服端关闭,cookie就会删除。0表示马上删除。正数表示有效时间,单位是秒。
  • setPath(String uri):设置cookie的作用域

HttpServletRequest和HttpServletResponse对Cookie进行操作的常见方法

  • response.addCookie(Cookie cookie):将cookie给客户端进行保存
  • resquest.getCookies():得到客服端传过来的所有cookie对象

Cookie应用实例

我们使用cookie来实现一个功能,就是当用户登录成功后,我们在下次登录时就自动填入用户名和密码。这个功能我们使用cookie和jsp页面来完成(用html页面也可以,只不过要使用javascript,有点麻烦,所以就使用jsp进行演示)

我们首先写一个简单的jsp页面,就是一个登录页面

  JSP页面

<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %><html><head><title>登录</title></head><body><form action="${pageContext.request.contextPath}/main" method="post">用户名:<input type="text" name="username" value="<%=request.getAttribute("username")%>"><br/>密 码:<input type="password" name="password" value="<%=request.getAttribute("password")%>"><br/><input type="submit" value="登录"></form></body>
</html>

请求转发页面,我们是通过访问Servlet转发到jsp页面的,而不是直接访问。

import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;
import java.io.IOException;@WebServlet("/cookieLogin")
public class CookieLogin extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {//设置默认值request.setAttribute("username","");request.setAttribute("password","");//得到所有cookieCookie[] cookies = request.getCookies();//对所有cookie进行遍历for (Cookie cookie : cookies) {//得到存储用户名和密码的cookie并且存入request域中if ("username".equals(cookie.getName())){String value = cookie.getValue();request.setAttribute("username",value);}if("password".equals(cookie.getName())){String value = cookie.getValue();request.setAttribute("password",value);}}//转发到login.jsp页面request.getRequestDispatcher("/login.jsp").forward(request,response);}@Overrideprotected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {this.doGet(request, response);}
}

登录成功后的首页

import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;
import java.io.IOException;@WebServlet("/main")
public class MainServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {//设置响应类型response.setContentType("text/html;charset=utf-8");//得到用户名和密码String username = request.getParameter("username");String password = request.getParameter("password");//判断是否登录成功if ("root".equals(username) && "root".equals(password)) {//编写cookieCookie usernameCookie = new Cookie("username", username);Cookie passwordCookie = new Cookie("password", password);//设置有效时间,我这里设置3天有效usernameCookie.setMaxAge(60 * 60 * 24 * 3);passwordCookie.setMaxAge(60 * 60 * 24 * 3);//存入客户端response.addCookie(usernameCookie);response.addCookie(passwordCookie);//返回提示response.getWriter().write("<h1>登录成功~~~~</h1>");}else {response.getWriter().write("<h1>登录失败....</h1>");}}@Overrideprotected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {this.doGet(request, response);}
}

下面我们来进行测试一下,首先访问http://localhost:8080/cs/cookieLogin,我们这里设置的虚拟路径是cs,下面是我们访问cookieLogin显示的页面。发现确实没有自动填写,因为我们还没有登录。游览器中也没有存有用户名和密码的cookie

输入正确的账号和密码进行登录。也就是账号和密码都输入root,页面显示登录成功

下面我们来查看游览器是否存储了用户名和密码的cookie

游览器确实存储了cookie,没有问题,接下来,我们关闭游览器后重新访问登录页面。

我们一访问登录页面,用户名和密码就自动填写了,成功实现了功能


总结

Cookie就是一些数据,用于存储服务器返回给客服端的信息,客户端进行保存。在下一次访问该网站时,客户端会将保存的cookie一同发给服务器,服务器再利用cookie进行一些操作。利用cookie我们就可以实现自动登录,保存游览历史,身份验证等功能。

cookie是什么?有什么用?cookie详解,一篇文章彻底搞懂cookie相关推荐

  1. cookie代码加时间多久出现一次_一文彻底搞懂Cookie、Session、Token到底是什么

    前言 在了解这三个概念之前我们先要了解HTTP是无状态的Web服务器,什么是无状态呢?就像上面夏洛特烦恼中经典的一幕对话一样,一次对话完成后下一次对话完全不知道上一次对话发生了什么.如果在Web服务器 ...

  2. Vue watch监听详解,一篇文章彻底搞懂Vue2/Vue3中的watch监听

    watch监听在vue2和vue3中的用法详解(全) Vue2中的watch用法 Vue3中的watch用法 首先写一个vue页面 <template><div><h1& ...

  3. 八、一篇文章快速搞懂MySQL 常见的数据类型(整型、小数、字符型、日期型详解)

    常见的数据类型 1.数值型: 整型 小数: 定点数 浮点数 2.字符型: 较短的文本:char.varchar 较长的文本:text.blob(较长的二进制数据) 3.日期型: 一.整型 1)分类: ...

  4. webpack5和webpack4详解(一篇全搞懂,值得收藏)

    文章目录 本篇的目的 1.webpack基础 1.1.webpack开发环境搭建 1.2.webpack配置核心 1.3.开发及生产环境分离 1.4.处理静态资源 2.webpack热门插件 2.1. ...

  5. 老鼠出迷宫详解(人人能搞懂)

    常见问题: 小伙伴们在第一次遇到该问题时,思路大家都能清楚,就是遇到走不通的时候就换方向走,但是却不知道代码是如何走的. 解决问题: 代码如下: public static void main(Str ...

  6. 【SVG】路径<Path>标签详解,一次搞懂所有命令参数

    在上一篇文章 什么是SVG?--SVG快速入门 中我对SVG做了基础的介绍,这篇文章将集中讲解<path>标签 本站链接:什么是SVG?--SVG快速入门_gxyzlxf的博客-CSDN博 ...

  7. PD3.1详解 第一章EPR

    ** PD3.1详解 第一章EPR ** 各大厂商逐渐在推广PD3.1的方案:从苹果的第一款PD3.1的适配器开始,目前慢慢的各种应用场合应用,比如一些电动工具,大功率储能产品等等. 首先PD3.1增 ...

  8. PD3.1详解 第二章(EPR)

    PD3.1详解 第二章(EPR) 第一章节简单的介绍了如何进入EPR模式,这里主要逐步说明具体的细节: 一. 如果需要进入EPR 那么所用的线必须要满要求,我们知道PD3.0中我们必须要有emark线 ...

  9. VB6.0 ActiveX 控件开发详解 [第一章:创建工程]

    前言 在CSDN的VB论坛上,我总是能够看见有人这样问"有没有这样的控件,一个列表框,每一个项前面有一个按钮"(这是例子),又或者见到这样:"怎么样做一个ActiveX控 ...

最新文章

  1. 中国人民大学_《组织行为学》_15如何降低集体决策的风险?
  2. ili9341屏幕在断电一段时间后首次上电白屏问题
  3. android log丢失(一)使用logd丢失log原理
  4. zend studio
  5. 【渝粤教育】电大中专幼儿园课程论 (10)作业 题库
  6. 第四十九期:大牛总结的MySQL锁优化,写得太好了!
  7. 【ClickHouse 技术系列】- ClickHouse 聚合函数和聚合状态
  8. druid mysql 配置优化_数据库连接池优化配置(druid,dbcp,c3p0)
  9. 你就非得 TCP?为啥不直接 UDP 呢!
  10. 灵雀云:etcd 集群运维实践
  11. 网页打开速度慢的原因及N种解决方法
  12. 举个栗子!Tableau技巧(22):如何导入其它地图源
  13. html修改网站图标,分享内容,分享图标等
  14. adb 连接某个wifi_adb wifi 测试(无需root)
  15. Mvp+OkHttp+XRecyclerView------上拉加载下拉刷新
  16. 假如大数据组件中的动物都变成神奇宝贝,那会变成什么样?(大数据的组件动漫化)
  17. error C251: illegal octal digit 错误提示
  18. Ajax与Json的使用
  19. 硬件开发——语音模块开发 (包含语音识别模块代码等资料包 )
  20. 泽塔云:用超融合撑起软件定义数据中心的梦想

热门文章

  1. 智慧政务解决方案-最新全套文件
  2. Unity技术分享之调用Youtu实现智能AI图像处理人脸识别,证照识别等
  3. ETL工具之Informatica
  4. 科技周刊第五期:科学技术在发展中的作用
  5. 破解梵蒂冈秘密档案,这个AI认识中世纪手写拉丁文
  6. 浅谈软件设计的七大原则
  7. CSDN如何转载他人文章
  8. MySql基本查询、连接查询、子查询、正则表达查询讲解
  9. 苹果手机来电归属地_工信部:手机号归属地不会取消、否则增大诈骗风险
  10. 蓝牙透传实验_蓝牙模块比较常见的通讯方式透传是什么