位置: IT常识 - 正文

客户端会话跟踪技术 Cookie 浅谈(实现会话跟踪的两种方式)

编辑:rootadmin
客户端会话跟踪技术 Cookie 浅谈 文章目录前言为什么之前浏览器和服务器不支持数据共享?会话跟踪技术Cookie的概念Cookie的工作流程Cookie的基本使用Cookie原理分析Cookie的存活时间Cookie存储中文前言

推荐整理分享客户端会话跟踪技术 Cookie 浅谈(实现会话跟踪的两种方式),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:会话跟踪技术的解决方案,客户端会话跟踪怎么设置,会话跟踪技术的解决方案,会话跟踪技术的解决方案,客户端会话跟踪怎么设置,常用的会话跟踪方法,客户端会话跟踪怎么关闭,客户端会话跟踪什么意思,内容如对您有帮助,希望把文章链接给更多的朋友!

用户打开浏览器,第一次访问 Web 服务器资源时,会话建立,直到有一方断开了连接则会话结束,例如浏览器或者服务器断开。在一次会话中可以包含多次的请求和响应。

上述的整个过程称为会话。

例如,当我们在浏览器访问一个网站时,浏览器和这个网站服务器就建立了一次会话,后面在这个网站中的所有操作都属于这一次会话,当我们关闭浏览器程序或者服务器关闭则会话结束。

现实中,服务器会被多个用户同时访问,为了识别多次请求是否来自同一个浏览器,在一次会话的多次请求间共享数据,出现了会话跟踪技术。会话跟踪技术是一种维护浏览器状态的方法,服务器识别浏览器的过程就被称为会话跟踪。

例如,实现购物车的功能中,第一次请求,用户将商品加入购物车,下一次请求,用户去购物车结算,第二次请求需要展示前一次添加到购物车中的商品,此时就要用到数据共享。再比如说页面展示用户的登录信息,网站登录页面记住密码等功能,都会用到数据共享。

为什么之前浏览器和服务器不支持数据共享?

之前说过,浏览器和服务器之间使用 HTTP 协议请求来传输数据,而 HTTP 协议是无状态的,也就是说浏览器发起的两次请求是毫不相干的,,每次浏览器向服务器发起请求时,服务器都会将该请求视为新的请求。

HTTP 协议之所以无状态,是因为该协议想让每次请求之间相互独立,互不影响,提高了性能,但是也伴随着多次请求之间数据无法共享的问题,而会话跟踪技术正是解决了这个难题。

会话跟踪技术

我们有两种方式来实现会话跟踪技术,分别是客户端会话跟踪技术 Cookie 和服务器会话跟踪技术 Session。其中 Cookie 是存储在客户端浏览器的,而 Session 是存储在服务器端的。两者各有利弊,接下来我们可以从两者的原理,使用等一同探讨。

什么是 Cookie,Cookie 是如何实现的?如何使用?接下来带着这些问题深入研究。

Cookie的概念

Cookie 是指客户端会话跟踪技术,其特点是将数据保存到客户端,以后每次请求都会携带 Cookie 数据进行访问。

Cookie的工作流程

浏览器发送 HTTP 请求给 Web 服务器资源时,服务器资源接收请求并进行业务处理,在这个过程中会创建一个 Cookie 对象,并将请求参数中的数据存入 Cookie。服务器响应数据时会把 Cookie 对象响应给浏览器,浏览器接收到响应后,会把 Cookie 中的数据存放到浏览器内存中,在同一次会话中浏览器再一次发送请求给 Web 服务器资源时,会携带 Cookie 对象中的所有数据。此时就实现了同一会话的不同请求之间的数据共享。

例如:

如上图,浏览器第一次访问 Web 服务器时,会话建立,那么如何实现一次会话的多次请求之间的数据共享呢?

浏览器发送 HTTP 请求 1 给服务器,服务器 Servlet 1 接收请求并进行业务处理,在处理过程中创建 Cookie 对象并将数据 name=zhangsan 存入 Cookie 。响应数据时,Cookie 对象被响应到浏览器,浏览器接收到响应数据会把 Cookie 对象中的数据存放到浏览器内存中,此时会话建立。

在同一次会话中,浏览器发送 HTTP 请求 2 给服务端 Servlet 2,此时会携带 Cookie 对象中所有的数据。 Servlet 2 接收到请求和数据后,就可以获取到 Cookie 对象中的数据,实现了一次会话中多次请求的数据共享。

Cookie的基本使用

对于 Cookie 的使用,我们主要关注后台代码对 Cookie 的操作,Cookie 的操作主要分为发送 Cookie 和接收 Cookie。

发送 Cookie:

创建 Cookie 对象:

Cookie cookie = new Cookie("key","value");

发送 Cookie 到浏览器:

response.addCookie(cookie);

下面练习将 Cookie 发送到客户端浏览器。

第一步:

创建 Maven Web 项目,命名为 cookie-demo,在 pom.xml 中添加相关依赖。

<dependencies> <!--servlet--> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> <scope>provided</scope> </dependency> <!--jsp--> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.2</version> <scope>provided</scope> </dependency> <!--jstl--> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <dependency> <groupId>taglibs</groupId> <artifactId>standard</artifactId> <version>1.1.2</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.2</version> </plugin> </plugins> </build>

第二步:编写 Servlet,编码:

@WebServlet("/servletA")public class ServletA extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //创建Cookie对象 Cookie cookie = new Cookie("name", "zhangsan"); //通过response发送Cookie对象 response.addCookie(cookie); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); }}

第三步:启动服务器,在浏览器中访问对象的服务器资源。

不难发现,此时响应数据中已经携带了 Cookie 的数据,如图:

浏览器中存储的 Cookie 数据怎么查看呢?一般情况下我们可以通过浏览器的设置查看,在不同的浏览器设置中一般都有 Cookie 选项,我们发现其中就存放了很多的 Cookie 数据。如图:

同样的我们也可以通过 F12 开发者工具查看,如图:

获取 Cookie:

获取客户端携带的所有 Cookie:

Cookie[] cookie = request.getCookies();

使用 Cookie 对象方法获取数据:

cookie.getName();cookie.getValue();

我们只需要遍历数组对象,并且使用 Cookie 对象方法,便可以获取每一个 Cookie 对象对应的值。

客户端会话跟踪技术 Cookie 浅谈(实现会话跟踪的两种方式)

下面练习获取浏览器请求中的 Cookie 数据。

第一步:编写一个 Servlet,命名为 ServletB,编码:

@WebServlet("/servletB")public class ServletB extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //获取Cookie数组 Cookie[] cookies = request.getCookies(); //遍历数组对象 for(Cookie cookie:cookies){ //获取数据 String name = cookie.getName(); if("name".equals(name)){ String value = cookie.getValue(); System.out.println(name+":"+value); break; } } } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); }}

第二步:在浏览器访问对应的资源,此时控制台输出了从浏览器获取的 Cookie 对象的值。如图:

在一次会话中,我们使用浏览器访问了两个不同的资源 ServletA 和 ServletB,并且实现了数据的共享。当我们关闭浏览器重新启动后访问 ServletB,此时会发现我们已经无法访问到 name:zhangsan 这条数据了。

Cookie原理分析

Cookie 的实现是基于 HTTP 协议的,其中涉及到了下面两个信息:

响应头:set-cookie请求头:cookie

例如在上面的案例中:

我们在前面的案例中使用 request 在 ServletB 中获取到了 Servlet 响应给浏览器的数据,在同一会话的两次请求之间实现了数据共享。

在 ServletA 响应数据时,Tomcat 服务器是基于 HTTP 协议来实现的,当 TomCat 发现要响应一个 Cookie 对象时,就会在响应头重添加数据:

set-Cookie:name=zhangsan

浏览器获取当响应结果后,从响应头中获取到对应的值 name=zhangsan ,并将数据存储在浏览器内存中。

在同一次会话中,浏览器发送 HTTP 请求给 ServletB,浏览器会自动在请求头中添加:

Cookie:name=zhangsan

服务器接收到浏览器的请求,Request 对象会将请求头中的 cookie 对应的值封装为 Cookie 对象,存放在数组中。此时我们就可以根据需求获取数据。

例如:

访问 ServletA 时,查看响应头数据如下:

访问 ServletB 时,查看请求头数据:

Cookie的存活时间

思考:

前面我们通过 ServletA 响应了存放 name=zhangsan 的 Cookie 对象给浏览器,浏览器接收响应数据并将 Cookie 数据存放到浏览器内存中,通过浏览器再次发送 HTTP 请求给 ServletB,并且使用 Response 对象获取了 Cookie 数据,那么在向 ServletB 发送请求之前,如果我们将浏览器彻底关闭并重新打开,还能通过 ServletB 获取到 Cookie 数据吗?

通过测试不难发现,如果将浏览器彻底关闭再次打来访问 ServletB 时,我们无法获取 Cookie 对象数据。

Cookie 的存活时间是指从创建到销毁的整个时间,那么 Cookie 对象能存活多久呢?

因为 Cookie 存放在浏览器内存中,所以在默认情况下,如果浏览器关闭,内存释放,此时 Cookie 就会被销毁。这也是为什么案例中我们再次打开浏览器无法获取 Cookie 的原因。

但是,有时我们需要 Cookie 的数据持久化存储,例如在实现登录时记住我的功能时,我们希望再次打开浏览器访问登录页面时,数据能被重新获取。Cookie 提供了对应的 API 来解决这个问题,我们可以通过 setMaxAge() 方法来设置 Cookie 的存活时间。

setMaxAge(int seconds)

参数为存活的秒数,通过设置其参数来控制 Cookie 的存活时间:

正数:将 Cookie 写入浏览器所在的电脑硬盘吗,持久化存储,到指定时间后自动删除负数:默认值,存放在浏览器内存中,浏览器关闭,内存释放,Cookie 销毁零:删除对应的 Cookie

示例:

@Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //创建Cookie对象 Cookie cookie = new Cookie("name", "zhangsan"); //设置Cookie存活时间 cookie.setMaxAge(60*60*24*7); //通过response发送Cookie对象 response.addCookie(cookie); }

设置完 Cookie 存活时间后,我们重启服务器,在浏览器访问 ServletA,重启浏览器,再次访问 ServletB,此时不难发现,Cookie 数据能够被获取到,说明 Cookie 并没有因为浏览器内存释放而销毁。

在浏览器设置中我们也可以看到,有些 Cookie 数据甚至设置存放一年之久。如图:

Cookie存储中文

其实在之前的案例中,如果我们设置的参数值为中文的话,在浏览器访问时会被提示错误信息的,因为 Cookie 是不能直接存储中文的。那么如果我们有存储中文的需求时该怎么解决这个问题呢?

这里就又要用到 URL 编码,具体怎么实现呢?

例如上面的例子中,在 ServletA 中响应 Cookie 数据时,对中文数据进行 URL 编码,并且将编码后的数据存放到 Cookie 中,在 Servlet 中获取 Cookie 的值时,只需要附加的进行 URL 解码,变不会出现中文乱码的问题。

示例:

第一步:在 ServletA 中进行 URL 编码:

@WebServlet("/servletA")public class ServletA extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //数据 String s = "张三"; //URL编码 String encode = URLEncoder.encode(s, "utf-8"); System.out.println(encode); //将编码后的数据存放到Cookie中 Cookie cookie = new Cookie("name", encode); //设置Cookie存活时间 cookie.setMaxAge(60*60*24*7); //通过response发送Cookie对象 response.addCookie(cookie); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); }}

访问服务器资源,如图:

第二步:在 ServletB 中进行 URL 解码:

@WebServlet("/servletB")public class ServletB extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //获取Cookie数组 Cookie[] cookies = request.getCookies(); //遍历数组对象 for(Cookie cookie:cookies){ //获取数据 String name = cookie.getName(); if("name".equals(name)){ //获取数据 String value = cookie.getValue(); //URL解码 value = URLDecoder.decode(value, "utf-8"); System.out.println(name+":"+value); break; } } } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); }}

访问服务器资源,如图:

此时,在控制台打印了没有乱码的中文数据。如图:

本文链接地址:https://www.jiuchutong.com/zhishi/299445.html 转载请保留说明!

上一篇:对 ChatGLM-6B 做 LoRA Fine-tuning

下一篇:前端搭建小人逃脱游戏(内附源码)

  • 微信删除评论后朋友圈还会显示内容吗(微信删除评论后24小时能看到吗)

    微信删除评论后朋友圈还会显示内容吗(微信删除评论后24小时能看到吗)

  • iphone se2可以无线充电吗(苹果se2能无线充电吗)

    iphone se2可以无线充电吗(苹果se2能无线充电吗)

  • 乐播投屏电视端打不开(下载乐播投屏电视端)

    乐播投屏电视端打不开(下载乐播投屏电视端)

  • 点亮soulmat需要多久(点亮soulmate需要多少条消息)

    点亮soulmat需要多久(点亮soulmate需要多少条消息)

  • intel virtualization technology什么意思(intel virtualization technology)

    intel virtualization technology什么意思(intel virtualization technology)

  • 抖音别人给我点赞怎么不显示(抖音别人给我点了赞又取消了 我的赞也没增加)

    抖音别人给我点赞怎么不显示(抖音别人给我点了赞又取消了 我的赞也没增加)

  • 手机芯片作用(世界芯片排名一览表)

    手机芯片作用(世界芯片排名一览表)

  • 得力计算器怎么关机(得力计算器怎么恢复出厂设置)

    得力计算器怎么关机(得力计算器怎么恢复出厂设置)

  • 无线有个感叹号是怎么回事(无线有个感叹号怎么解决)

    无线有个感叹号是怎么回事(无线有个感叹号怎么解决)

  • 小程序没有域名怎么办(小程序没有域名可以用吗)

    小程序没有域名怎么办(小程序没有域名可以用吗)

  • 苹果11屏幕有时会突然暗下来(苹果11屏幕有时候点不动)

    苹果11屏幕有时会突然暗下来(苹果11屏幕有时候点不动)

  • 手机进水白屏会自己恢复吗(手机进水白屏会烧屏吗)

    手机进水白屏会自己恢复吗(手机进水白屏会烧屏吗)

  • 钉钉悬浮窗记录观看时长吗(钉钉开悬浮窗会不会记录时间)

    钉钉悬浮窗记录观看时长吗(钉钉开悬浮窗会不会记录时间)

  • 网易云音乐tv版怎么弄(网易云音乐TV版怎么打开歌词)

    网易云音乐tv版怎么弄(网易云音乐TV版怎么打开歌词)

  • 群主能删除群成员发的消息吗(群主能删除群成员发的文件吗)

    群主能删除群成员发的消息吗(群主能删除群成员发的文件吗)

  • 流量语音共享是什么(语音流量共享套餐是什么意思)

    流量语音共享是什么(语音流量共享套餐是什么意思)

  • 手机上出现hd怎么去掉(手机上出现HD怎么打开)

    手机上出现hd怎么去掉(手机上出现HD怎么打开)

  • vivoy71怎么解决卡顿(vivoy71a手机)

    vivoy71怎么解决卡顿(vivoy71a手机)

  • ipad air3能用pencil吗(iPad air3能用2代pencil吗)

    ipad air3能用pencil吗(iPad air3能用2代pencil吗)

  • 乐视2手机怎么拆后盖(乐视2手机怎么刷机教程)

    乐视2手机怎么拆后盖(乐视2手机怎么刷机教程)

  • 紧急呼叫怎么取消(紧急呼叫从哪里取消)

    紧急呼叫怎么取消(紧急呼叫从哪里取消)

  • 抖音怎么配字幕(抖音怎么配字幕加声音)

    抖音怎么配字幕(抖音怎么配字幕加声音)

  • Linux中文件的压缩与解压缩命令操作示例集锦(linux 文件夹压缩)

    Linux中文件的压缩与解压缩命令操作示例集锦(linux 文件夹压缩)

  • web服务器的搭建【CentOS7】(web服务器的搭建与应用)

    web服务器的搭建【CentOS7】(web服务器的搭建与应用)

  • 进项税额转出的几种情况会计分录
  • 已开普通发票记账联丢失怎么办?
  • 非增值税应税项目可以抵扣进项税吗
  • 吊车租赁可以开6个点专票吗
  • 代办汽车过户手续
  • 企业退回企业所得税分录
  • 减免的所得税额怎么入账
  • 贸易型出口退税流程
  • 价外收取的返还利润是什么意思
  • 小规模纳税人销售额
  • 境外企业向境内提供国际运输服务核定征收的企业所得税
  • 年报所得税与季报的区别
  • 房地产增值税发票有什么用
  • 银行美元账户调汇会计分录
  • 货币的时间价值名词解释
  • 个人独资企业改为有限公司
  • 税控专用发票和普通发票
  • 注册资本的变更
  • 稿酬所得个人所得税计算方法
  • 房地产开发企业会计科目
  • 差额纳税和全额纳税比例
  • 办理税务登记与办理法人企业有何区别?
  • 企业个税网上申报时间
  • 老板垫付的货款怎么做凭证?
  • 公司账款无法收回扣款合法吗
  • 怎样删除电脑系统账户
  • 股权转让定金怎么做账
  • 回迁房办理房产证契税怎么交
  • 库存现金被盗会怎么样
  • 水利建设基金的计税依据及税率
  • 工具人
  • php图片上传代码详解
  • 时间序列garch
  • pca降维的原理
  • ci框架视频教程
  • 公司是否可以开具在职证明
  • 红字信息表重复了怎么办
  • 应付票据的贴现账务处理
  • 税金及附加也是费用吗
  • 员工工资计提
  • 抵扣完进项怎么算应交增值税
  • sql计算字符串中文个数
  • mongodb基本操作
  • 小程序集合软件
  • 总公司所得税汇算
  • 白条怎么收拾
  • 开票资料需要哪些东西
  • 金蝶余额调节表勾对日期什么意思
  • 母公司与子公司的区别
  • 段云简介
  • 采用公允价值模式计量的投资性房地产处置
  • 购买原材料的支出
  • 公司健身器材使用制度
  • 收到商业汇票怎么入账
  • 期末余额和期初余额
  • 未开发票已收款如何做账?
  • 备查账依据什么登记
  • 劳动者权益包含哪些
  • 磁盘缓存技术
  • mysql删除有外键关联的数据
  • sql获取guid
  • ubuntu系统怎样
  • win8.1设备管理器设置步骤
  • 在microsoft store
  • win7系统打不开网络和共享中心
  • windows8如何调用摄像头
  • win10命令提示符需要密码
  • unity3d Hair real time rendering 真实头发实时渲染
  • js中的常用方法
  • Unity3D游戏开发培训课程大纲
  • JavaScript中Math.SQRT2属性的使用详解
  • python 转换为字符
  • js实现文字闪烁的方法
  • 工会经费申报表在哪里查询
  • 全国残疾人工作先进个人
  • 增值税和消费税申报对比不符怎么处理
  • 2023年印花税税目表
  • 地税局属于市直单位吗
  • 江苏几个地级市几个县级市
  • 局党组中心组成员
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设