cookie

news2024/11/24 18:39:07

cookie 

Cookie是一个客户端会话技术,是由服务器端创建,放在响应头发送到客户端保存,用于存储少量数 据,因为存放在客户端中,容易被人编造伪造,不是很安全。一般不用于存储重要信息。它是通过键值对传递信息的。

Cookie是保存在客户端的数据,所以如果不做设定,默认情况下是跟着客户端一起消失,如果设置 setMaxAge(),将会以设置的数值为主,时间到了将会自动消失

  • Cookie是服务器通知客户端保存键値对的一种技术
  • 客戶端有了 Cookie后,每次请求都发送给服务器
  • 每个 Cookie的大小不能超过4kB,超过这个限制cookie中无法存储该数据

Cookie应用场景 

  • Cookie能使站点跟踪特定访问者的访问次数、最后访问时间和访问者进入站点的路径
  • Cookie能告诉在线广告商广告被点击的次数,从而可以更精确的投放广告
  • Cookie有效期限未到时,Cookie能使用户在不键入密码和用户名的情况下进入曾经浏览过的一些 站点
  • Cookie能帮助站点统计用户个人资料以实现各种各样的个性化服务
  • 安全性能差,容易信息泄露 

基础编程

添加cookie 

Cookie ck1 = new Cookie("username", username); //创建cookie对象,注意cookie中只
能存放字符串,其它数据可以转换为字符串进行存储,默认maxAge为-1,表示采用内存cookie
response.addCookie(ck1); //将cookie发送到客户端

读取cookie

Cookie[] cks = request.getCookies();//获取当前应用可以访问的所有cookie
String username = null;
for (Cookie ck : cks) { //遍历所有的cookie,根据名称查找对应的存储数据
    if ("username".equals(ck.getName())) {
        username = ck.getValue();
    }
}

void setValue(String newValue) cookie创建后设置一个新的值。

String getName()返回Cookie的名字。名字和值是关心的两个部分

String getValue() 返回Cookie的值

具体的cookie可以分为内存cookie和文件cookie, Cookie ck=new Cookie("username","zhangsan") 时默认maxAge为 -1表示内存cookie,内存cookie在浏览器窗口关 闭后会自动消失;如果需要使用文件cookie则需要设置maxAge,参数为正整数

void setMaxAge(int expiry) 以秒计算,设置Cookie过期时间。注意这个值是cookie将要存在的最大时 间,而不是cookie现在的存在时间。负值表示当浏览器关闭时,Cookie将会被删除。零值则是要删除该 Cookie

int getMaxAge() 返回Cookie过期之前的最大时间,以秒计算。

文件cookie不受当前窗口是否关闭的影响

Cookie ck=new Cookie("name","wangwu");
ck.setMaxAge(15*24*60*60);//需要存储15天,例如15天免登录
response.addCookie(ck);

void setComment(String purpose) 设置cookie中注释。 

String getComment()返回cookie中注释,如果没有注释的话将返回空值 

String getDomain() 返回cookie中Cookie适用的域名。使用getDomain() 方法可以指示浏览器把Cookie 返回给同 一域内的其他服务器,而通常Cookie只返回给与发送它的服务器名字完全相同的服务器。注意 域名必须以点开始,如.yesky.com) 

void setDomain(String pattern) 设置cookie中Cookie适用的域名 

String getPath()返回Cookie适用的路径。如果不指定路径,Cookie将返回给当前页面所在目录及其子目 录下 的所有页面 

 void setPath(String uri) 指定Cookie适用的路径。

其它方法

boolean getSecure() 如果浏览器通过安全协议发送cookies将返回true值,如果浏览器使用标准协议则 返回false值。

int getVersion() 返回Cookie所遵从的协议版本。

void setSecure(boolean flag) 指出浏览器使用的安全协议,例如HTTPS或SSL。

void setVersion(int v) 设置Cookie所遵从的协议版本。 

Cookie原理

对于Cookie的实现原理是基于HTTP协议的,其中设计HTTP协议中的两个请求头信息分别为:响应头 set-cookie、请求头cookie

[response.addCookie]当要发送Cookie的时候会有一个响应头set-cookie,里面放着数据,当将来浏览 器在请求服务器资源的时候,会通过一个cookie头把cookie的数据携带到服务器资源里面来请求 

Cookie限制性 

cookie存储大小一般为4kB,存储个数一般20-53个,视浏览器的不同。 

Cookie通讯过程

Cookie在通讯中会经历4个过程:

  • 浏览器发送请求
  • 服务端接收请求,并返回响应,在报文头中包含set-cookie的字段
  • 浏览器接收响应后将Cookie存储,并在之后的请求中都会带上cookie的信息
  • 服务端接收请求,并返回响应。 

Cookie属性

Cookie的属性有:key/value、Expires、Domain、path、Secure、HttpOnly

  • Key/value键值对,cookie按照键值对的模式存储信息
  • Expires过期时间,设置某个时间后,cookie会失效
  • Domain指定Cookie的域名作用域
  • Path是Cookie生成的路径
  • Secure只有在HTTPS模式下,服务端才会响应cookie信息
  • HttpOnly设为true后,只能通过http访问,不能通过document.cookie获取设定为httponly的键 值,防止xss读取cookie 

maxAge

标准用法 

Cookie ck=new Cookie("name","wangwu");
// ck.setMaxAge(15*24*60*60);//需要存储15天,例如15天免登录
ck.setMaxAge(0); //删除cookie
response.addCookie(ck);

 基于语法 cookie.setMaxAge(60); 单位为秒。

  • 当maxAge >0时Cookie将在maxAge秒后自动失效
  • 当maxAge =0时Cookie将立刻删除Cookie
  • 当maxAge =-1时Cookie的时间过期后cookie依然存在在浏览器上,将存在一段时间或重启浏览器 自动消失。 

 HttpServletResponse提供的Cookie操作只有一个addCookie,如果要修改Cookie只能用一个同名的 Cookie进行覆盖。

客户端发送的cookie时,只会提交name和value属性,其他属性是不可读的。也不会被提交。即服务端 无法判断Cookie是否过期,获取域名信息等。如在服务端通过cookie.getMaxAge()获取过期时间,读取 的是一个只读属性,值永远为-1。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/13651.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

载波通信在电网智能化中的应用

目录载波通信在电网智能化中的应用电力载波通信特点电力载波通信在电力智能化中应用载波数据通信载波语音通信高速电力线通信(HPLC)载波通信在电网智能化中的应用 电力载波通信特点 电力载波通信(Power line Communication)即PL…

Nginx防盗链

资源盗链 资源盗链指的是此内容不在自己服务器上,而是通过技术手段,绕过别人的限制将别人的内容放到自己页面上最终展示给用户。以此来盗取大网站的空间和流量。简而言之就是用别人的东西成就自己的网站。 案例 创建steal.html,页面引用两…

视频直播美颜SDK算法代码解析

随着短视频、直播软件一类app的流行,美颜sdk的应用也越来越广泛。所谓“美颜”,简单解释下,就是通过视频(图片)技术对人脸进行美化。但是就“美化”这个词,却牵扯到众多深度学习、图像处理、图像学技术。今…

vant-list上滑加载,数据重复,加载后返回顶部

(1)vant-list上滑加载 list这个组件,必须具有高度,才能实现上滑加载,不然不会有上滑加载的过程。 因为没有高度,相当于整个屏幕都是组件的,就没有底部一说,所以会一直加载所有的&…

Debye-Wolf积分计算器的用法

摘要 众所周知,Debye-Wolf积分可用于以半解析的方式计算焦平面附近的矢量场。Debye-Wolf积分通常用作分析高数值孔径显微镜成像情况的基本工具。 基于理想化模型,因此不需要精确的镜头规格即可进行计算。 该案例将说明如何在VirtualLab中使用Debye-Wolf积…

[力扣] 剑指 Offer 第三天 - 替换空格

[力扣] 剑指 Offer 第三天 - 替换空格题目来源题目描述示例题目分析算法代码实现执行结果复杂度分析总结耐心和持久胜过激烈和狂热。 题目来源 来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/ti-huan-kong-ge-lcof 著作…

什么是CUSDEC 报关单?

CUSDEC即Customs Declaration Message,中文解释是报关单,符合EDIFACT国际报文标准。 报关单信息 (CUSDEC) 允许将数据从报关员转移到海关管理部门,以满足有关进口、出口或过境货物申报的立法或操作要求。这个报文的应用场景还包括&#xff1…

【Hack The Box】windows练习-- Intelligence

HTB 学习笔记 【Hack The Box】windows练习-- Intelligence 🔥系列专栏:Hack The Box 🎉欢迎关注🔎点赞👍收藏⭐️留言📝 📆首发时间:🌴2022年9月7日🌴 &…

C++11更新内容(2)--完美转发--默认移动构造/移动赋值--1116

1.完美转发 1.1万能引用 void Fun(int &x){ cout << "左值引用" << endl; } void Fun(const int &x){ cout << "const 左值引用" << endl; }void Fun(int &&x){ cout << "右值引用" << e…

分布式数据库Cassandra

目录 一、概述 1、简介 2、架构 3、使用场景 二、安装 三、基本概念 1、数据模型 列&#xff08;Column&#xff09; 列族 KeySpace 节点&#xff08;Node&#xff09; 集群&#xff08;Cluster&#xff09; 2、数据类型 基础类型 集合类型 自定义数据类型 …

Linux开发工具(3)——gcc/g++

文章目录Linux编译器——gcc/g程序编译背景知识gcc指令动态链接和静态链接Linux下运行其他语言Linux编译器——gcc/g 程序编译背景知识 程序的编译分为四步&#xff1a; 预处理&#xff1a;主要完成的是&#xff0c;头文件展开&#xff0c;宏替换&#xff0c;注释删除&#x…

基于Matlab使用GPU和代码加速杂波模拟(附源码)

目录 一、杂波模拟 二、比较杂波模拟时间 三、其他仿真时序结果 四、总结 五、程序 此示例演示如何在图形处理单元 &#xff08;GPU&#xff09; 上或通过代码生成 &#xff08;MEX&#xff09; 而不是 MATLAB 解释器来模拟混乱。该示例将样本矩阵反演 &#xff08;SMI&am…

DVWA靶场在sql注入联合查询时返回报错信息 “Illegal mix of collations for operation ‘UNION’ ”之解决

比如我们输入&#xff1a; -1 union select 1,table_name from information_schema.tables where table_schemadvwa#会跳出一个页面出现报错提示&#xff1a; Illegal mix of collations for operation UNION这是由于union连接数据库中的字段的字符规则不一样导致的错误&…

MySQL—Apache+PHP+MySQL实现网上社区

ApachePHPMySQL实现网上社区 所谓网上社区是指包括BBS/论坛、聊天室、博客等形式在内的网上交流空间&#xff0c;同一主题的网上社区集中了具有共同兴趣的访问者&#xff0c;由于有众多用户的参与&#xff0c;因此具备了交流的功能&#xff0c;成为一个营销场所。网上社区有各…

高质量实现单文件导入、导出功能(使用EasyExcel )

前言 咋说呢&#xff0c;最近交接了一个XXX统计分析系统到我手上&#xff0c;显示页面平平无其&#xff0c;一看导入、导出功能的实现代码&#xff0c;每个小菜单目录里面都对应一个导入导出接口&#xff0c;看起来十分难受&#xff01;&#xff08;此处省略1w字内心os&#xf…

Neo4j安装与配置

注意&#xff1a;在安装Neo4j之前要安装JAVA SE的SDK。 1. 下载Neo4j 企业版本的收费的&#xff0c;社区版本是免费的。我下载的是社区版本。 社区版本下载地址&#xff1a;https://neo4j.com/download-center/#community 我下载的是3.5.35 下载好以后是zip文件&#xff0c;…

vulnhub靶机raven1

靶机下载地址&#xff1a;Raven: 1 ~ VulnHub Kali ip&#xff1a;192.168.174.128 靶机ip&#xff1a;192.168.174.131 实验思路&#xff1a;靶机ip发现&#xff0c;端口扫描&#xff0c;wordpress用户枚举和爆破&#xff0c;ssh爆破&#xff0c;MySQL登录&#xff0c;pyth…

云计算存储虚拟化技术

存储虚拟化是指将具体的存储设备或存储系统与服务器操作系统分隔开&#xff0c;为存储用户提供一个统一的虚拟存储池。 在面对资源池按需分配、多租户、海量存储、高I/O、快速扩展、差异化服务等需求时&#xff0c;传统的存储方式面临的挑战日益明显&#xff0c;存储成本高、并…

kali(linux)安装fscan

fscan 是一个内网综合扫描工具&#xff0c;方便一键自动化、全方位漏洞扫描。 它支持主机存活探测、端口扫描、常见服务的爆破、ms17010、redis批量写公钥、计划任务反弹shell、读取win网卡信息、web指纹识别、web漏洞扫描、netbios探测、域控识别等功能。 源码链接&#xff…

2022.11.17 HDU-4911 Inversion

bobo has a sequence a1,a2,…,an. He is allowed to swap two adjacent numbers for no more than k times. Find the minimum number of inversions after his swaps. Note: The number of inversions is the number of pair (i,j) where 1≤i<j≤n and ai>aj. Input T…