客户端会话技术-Cookie
一、会话技术
1.1 概述
会话:一次会话中包含多次**请求和响应**
一次会话:浏览器第一次给服务器资源发送请求,此时会话建立,直到有一方断开为止
会话的功能:在一次会话的范围内的多次请求间,共享数据
会话的方式
- 客户端会话技术:Cookie
- 服务器端会话技术:Session
二、Cookie
2.1 概述和快速入门
概述:客户端会话技术,将数据保存到客户端,在B/S架构中,即浏览器中
使用步骤:
- 创建 Cookie 对象,绑定数据
- 发送 Cookie 对象
- 获取 Cookie 对象,拿到数据
方法:
方法 | 作用 |
---|---|
new Cookie(String name , String value) | 创建 Cookie 对象 |
response.addCookie(Cookie cookie) | 通过 响应对象 进行发送 |
Cookie[] request.getCookies() | 通过 请求对象 进行获取 |
2.2 Cookie 原理
Cookie 的实现原理,底层发送数据还是基于 http 协议,基于 响应头 set-cookie 和 请求头 cookie 实现
2.3 Cookie 的细节
1、一次可不可以发送多个 Cookie?
- 可以创建多个 Cookie 对象,使用 response 响应对象调用多次 addCookie 方法发送 cookie 即可
2、Cookie 在浏览器中保存多长时间?
-
默认情况下,当浏览器关闭后,Cookie 数据就被销毁
-
持久化存储(设置 Cookie 的生命周期)
setMaxAge(int seconds);
- 参数
- 正数:将 Cookie 数据写到硬盘的文件中,持久化存储,并指定Cookie存活时间,时间到后,Cookie文件自动失效(单位:秒)
- 负数:默认值
- 零:删除 Cookie 信息
- 参数
3、Cookie 能不能存储中文?
- 在 Tomcat 8 之前 Cookie 中不能直接存储中文数据,需要将中文数据转码,一般采用 URL 编码
- 在 Tomcat 8 之后 Cookie 中支持中文数据,特殊字符还是不支持,建议使用 URL 编码存储,URL 解码解析
4、假设在一个 Tomcat 服务器中,部署了多个 web 项目,那么在这些 web 项目中 Cookie 能不能共享?
-
默认情况下 Cookie 是不能共享的,如果要共享,可以将 path 设置为 “/”
-
设置方法
setPath(String path); // 设置 cookie 的获取范围,默认情况下设置当前的虚拟目录
5、不同 Tomcat 服务器间 Cookie 共享问题?
-
如果设置一级域名相同,那么多个服务器之间 Cookie 可以共享
-
设置方法
setDomain(String path); // 设置域名
-
示例代码
setDomain(".baidu.com"); // 那么 只要是此一级域名下的域名中 Cookie 都能共享
2.4 Cookie 的特点和作用
Cookie 存储数据在客户端浏览器中,浏览器对于单个 Cookie 的大小有限制(4kb)以及对同一个域名下、总的Cookie 数量也有限制(20个)
- Cookie 一般用于存储少量的不太敏感的数据
- 在不登录的情况下,完成服务器对客户端的身份识别(例子:我们对某个网站登录后,发现下次再来就会有账户)
三、案例
3.1 记住上一次访问时间
案例需求:
- 访问一个 Servlet ,如果是首次访问,则提示:“您好,欢迎您首次访问”
- 如果不是第一次访问,则提示:“欢迎回来,您上次访问时间为:年月日 时分秒”
案例分析:
- 可以采用 Cookie 客户端会话技术来实现
- 在服务器中 Servlet 判断是否有一个名为 lastTime 的 Cookie 对象
- 有:则不是第一次访问
- 响应数据:将 “欢迎回来,您上次访问时间为:时间” 输出到浏览器上
- 写回 Cookie:将 本次访问时间 以 Cookie 对象方式存储到客户端
- 无:则是第一次访问
- 响应数据:将 “您好,欢迎您首次访问” 输出到浏览器上
- 写回 Cookie:将 本次访问时间 以 Cookie 对象方式存储到客户端
- 有:则不是第一次访问
案例过程图:
案例代码:
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.net.URLDecoder;
import java.net.URLEncoder;
import java.text.SimpleDateFormat;
import java.util.Date;/*** Cookie 案例:记录上一次时间*/
@WebServlet("/servlet1")
public class CookieDemo1 extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {resp.setContentType("text/html;charset=utf-8");PrintWriter out = resp.getWriter();// 获取客户端的所有 CookieCookie[] cookies = req.getCookies();boolean isFirstVisit = true;String lastVisitTime = "";if (cookies != null) {for (Cookie cookie : cookies) {if (cookie.getName().equals("lastTime")) {isFirstVisit = false;// 采用 URL 解码lastVisitTime = URLDecoder.decode(cookie.getValue(),"utf-8");break;}}}if (isFirstVisit) {out.println("您好,欢迎您首次访问");} else {out.println("欢迎回来,您上次访问时间为:" + lastVisitTime);}// 将本次访问时间以 Cookie 对象方式存储到客户端SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String currentTime = dateFormat.format(new Date());// 采用 URL 编码String encode = URLEncoder.encode(currentTime, "utf-8");Cookie lastTimeCookie = new Cookie("lastTime", encode);resp.addCookie(lastTimeCookie);out.close();}
}
相关文章:

客户端会话技术-Cookie
一、会话技术 1.1 概述 会话:一次会话中包含多次**请求和响应** 一次会话:浏览器第一次给服务器资源发送请求,此时会话建立,直到有一方断开为止 会话的功能:在一次会话的范围内的多次请求间,共享数据 …...
rsa加密登录解决方案
1.问题 账密登录方式中用户输入密码后,把账号、密码通过http传输到后端进行校验,然而密码属于敏感信息,不能以明文传输,否则容易被拦截窃取,因此需要考虑如何安全传输密码 2.解决方案 使用rsa加密方式,r…...
速盾:海外服务器用了cdn还是卡怎么办
海外服务器使用CDN卡顿问题的解决办法 在如今互联网高速发展的时代,海外服务器成为了许多企业和个人用户的首选,因为它能够提供更高的带宽和更稳定的网络连接。然而,尽管海外服务器在网络性能方面表现出色,但在使用过程中仍然可能…...
[python-opencv] PNG 裁切物体
拿到一组图PNG的图,边缘有点太宽了,需要裁切一下,为了这个需求,简单复习一下基本语法。 1. 读取PNG的4个通道 image cv.imread(image_path, cv.IMREAD_UNCHANGED) 附参数说明: IMREAD_UNCHANGED -1 返…...

机器学习——有监督学习和无监督学习
有监督学习 简单来说,就是人教会计算机学会做一件事。 给算法一个数据集,其中数据集中包含了正确答案,根据这个数据集,可以对额外的数据希望得到一个正确判断(详见下面的例子) 回归问题 例如现在有一个…...
MySQL单主模式部署组复制集群
前言 本篇文章介绍MySQL8.0.27版本的组复制详细搭建过程,教你如何快速搭建一个三节点的单主模式组复制集群。 实际上,MySQL组复制是MySQL的一个插件 group_replication.so,组中的每个成员都需要配置并安装该插件,配置和安装过程…...

【大厂AI课学习笔记】【1.5 AI技术领域】(10)对话系统
对话系统,Dialogue System,也称为会话代理。是一种模拟人类与人交谈的计算机系统,旨在可以与人类形成连贯通顺的对话,通信方式主要有语音/文本/图片,当然也可以手势/触觉等其他方式 一般我们将对话系统,分…...

【ARM 嵌入式 编译系列 2.7 -- GCC 编译优化参数详细介绍】
请阅读【嵌入式开发学习必备专栏 】 文章目录 GCC 编译优化概述常用优化等级-O1 打开的优化选项-O2 打开的优化选项-O3 打开的优化选项-Os 打开的优化选项优化技术使用优化选项的注意事项GCC 编译优化概述 GCC(GNU Compiler Collection)包含了用于C、C++、Objective-C、Fort…...

《剑指 Offer》专项突破版 - 面试题 38、39 和 40 : 通过三道面试题详解单调栈(C++ 实现)
目录 面试题 38 : 每日温度 面试题 39 : 直方图最大矩形面积 方法一、暴力求解 方法二、递归求解 方法三、单调栈法 面试题 40 : 矩阵中的最大矩形 面试题 38 : 每日温度 题目: 输入一个数组,它的每个数字是某天的温度。请计算每天需要等几天才会…...
动态规划C语言
#include <stdio.h> #include <stdlib.h> //0-1背包问题是一种经典的组合优化问题, //问题描述为:有一个给定容量的背包和一组具有不同价值和重量的物品,如何选择物品放入背包中,以使得背包中物品的总价值最大化&…...

基于微信小程序的校园二手交易平台
博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…...

K8S系列文章之 [使用 Alpine 搭建 k3s]
官方文档:K3s - 轻量级 Kubernetes | K3s 官方描述,可运行在 systemd 或者 openrc 环境上,那就往精简方向走,使用 alpine 做系统。与 RHEL、Debian 的区别,主要在防火墙侧;其他基础配置需求类似࿰…...

计算机视觉 | OpenCV 实现手势虚拟控制亮度和音量
Hi,大家好,我是半亩花海。在当今科技飞速发展的时代,我们身边充斥着各种智能设备,然而,如何更便捷地与这些设备进行交互却是一个不断被探索的课题。本文将主要介绍一个基于 OpenCV 的手势识别项目,通过手势…...

python28-Python的运算符之三目运算符
Python可通过if语句来实现三目运算符的功能,因此可以近似地把这种if语句当成三目运算符。作为三目运算符的f语句的语法格式如下 True_statements if expression else False_statements 三目运算符的规则是:先对逻辑表达式expression求值,如果逻辑表达式…...

高德 API 10009
问题 笔者使用高德地图所提供的API接口,访问接口报错 {"info":"USERKEY_PLAT_NOMATCH","infocode":"10009","status":"0","sec_code_debug":"d41d8cd98f00b204e9800998ecf8427e"…...

Go 语言中如何大小端字节序?int 转 byte 是如何进行的?
嗨,大家好!我是波罗学。 本文是系列文章 Go 技巧第十五篇,系列文章查看:Go 语言技巧。 我们先看这样一个问题:“Go 语言中,将 byte 转换为 int 时是否涉及字节序(endianness)&#x…...

论文阅读——MP-Former
MP-Former: Mask-Piloted Transformer for Image Segmentation https://arxiv.org/abs/2303.07336 mask2former问题是:相邻层得到的掩码不连续,差别很大 denoising training非常有效地稳定训练时期之间的二分匹配。去噪训练的关键思想是将带噪声的GT坐标…...

JPEG图像的压缩标准(1)
分3个博客详细介绍JPEG图像的压缩标准,包含压缩和解压缩流程,熵编码过程和文件存储格式。 一、JPEG压缩标准概述 JPEG压缩标准由国际标准化组织 (International Organization for Standardization, ISO) 制订,用于静态图像压缩。JPEG标准包…...
数解 transformer 之 self attention transformer 公式整理
句子长度为n;比如2048,或1024,即,一句话最多可以是1024个单词。 1, 位置编码 可知,E是由n个列向量组成的矩阵,每个列向量表示该列号的位置编码向量。 2, 输入向量 加入本句话第一个单词的词嵌入向量是, 第…...
ubuntu22.04@laptop OpenCV Get Started
ubuntu22.04laptop OpenCV Get Started 1. 源由2. 步骤3. 预期&展望4. 参考资料 1. 源由 OpenCV在学校的时候接触过,不过当时专注在物理、研究方面,没有好好的学习下。 这次借后续视频分析刚性需求,对OpenCV做个入门的学习和研读&#…...

IDEA运行Tomcat出现乱码问题解决汇总
最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…...

装饰模式(Decorator Pattern)重构java邮件发奖系统实战
前言 现在我们有个如下的需求,设计一个邮件发奖的小系统, 需求 1.数据验证 → 2. 敏感信息加密 → 3. 日志记录 → 4. 实际发送邮件 装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其…...
Linux链表操作全解析
Linux C语言链表深度解析与实战技巧 一、链表基础概念与内核链表优势1.1 为什么使用链表?1.2 Linux 内核链表与用户态链表的区别 二、内核链表结构与宏解析常用宏/函数 三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势5.1 插入效率5.2 安全…...

智慧工地云平台源码,基于微服务架构+Java+Spring Cloud +UniApp +MySql
智慧工地管理云平台系统,智慧工地全套源码,java版智慧工地源码,支持PC端、大屏端、移动端。 智慧工地聚焦建筑行业的市场需求,提供“平台网络终端”的整体解决方案,提供劳务管理、视频管理、智能监测、绿色施工、安全管…...
在四层代理中还原真实客户端ngx_stream_realip_module
一、模块原理与价值 PROXY Protocol 回溯 第三方负载均衡(如 HAProxy、AWS NLB、阿里 SLB)发起上游连接时,将真实客户端 IP/Port 写入 PROXY Protocol v1/v2 头。Stream 层接收到头部后,ngx_stream_realip_module 从中提取原始信息…...

学习STC51单片机31(芯片为STC89C52RCRC)OLED显示屏1
每日一言 生活的美好,总是藏在那些你咬牙坚持的日子里。 硬件:OLED 以后要用到OLED的时候找到这个文件 OLED的设备地址 SSD1306"SSD" 是品牌缩写,"1306" 是产品编号。 驱动 OLED 屏幕的 IIC 总线数据传输格式 示意图 …...
Linux云原生安全:零信任架构与机密计算
Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...

C# 类和继承(抽象类)
抽象类 抽象类是指设计为被继承的类。抽象类只能被用作其他类的基类。 不能创建抽象类的实例。抽象类使用abstract修饰符声明。 抽象类可以包含抽象成员或普通的非抽象成员。抽象类的成员可以是抽象成员和普通带 实现的成员的任意组合。抽象类自己可以派生自另一个抽象类。例…...

ios苹果系统,js 滑动屏幕、锚定无效
现象:window.addEventListener监听touch无效,划不动屏幕,但是代码逻辑都有执行到。 scrollIntoView也无效。 原因:这是因为 iOS 的触摸事件处理机制和 touch-action: none 的设置有关。ios有太多得交互动作,从而会影响…...

RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)
RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发,后来由Pivotal Software Inc.(现为VMware子公司)接管。RabbitMQ 是一个开源的消息代理和队列服务器,用 Erlang 语言编写。广泛应用于各种分布…...