文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-08-31 19:55

关注

Cookie是什么

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


Cookie有什么用

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

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


Cookie的表示 

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


Cookie的组成

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

         以下是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使用的常见方法

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

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


Cookie应用实例

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

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

        JSP页面

<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>      登录      
用户名:">
密 码:">

请求转发页面,我们是通过访问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 {    @Override    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {        //设置默认值        request.setAttribute("username","");        request.setAttribute("password","");        //得到所有cookie        Cookie[] 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);    }    @Override    protected 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 {    @Override    protected 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)) {            //编写cookie            Cookie 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("");        }else {            response.getWriter().write("");        }    }    @Override    protected 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我们就可以实现自动登录,保存游览历史,身份验证等功能。

来源地址:https://blog.csdn.net/m0_51545690/article/details/123359959

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-服务器
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯