深入了解 Session 与 Cookie
Java —— 深入了解 Session 与 Cookie
Java web
了解Cookie和Session
定义
1、很通俗的来讲,Cookie就是浏览器的缓存,就是用户访问网站时保存在浏览器的一小段文本信息。
2、很通俗的来讲,Session就是会话控制,一个会话就是一个浏览器访问该网站的整个过程。Session把关于本次会话的配置信息以及该用户的一些信息保存在服务端。
区别
1、大家都是缓存,Cookie是保存在客户端(浏览器),Session是保存在服务端。
2、Cookie的保存时间自由设定,当超过设定时间时Cookie过期,过期后信息被删除。Session的保存时间也是自由设定,不过一般设定为半个小时,超过设定时间或者会话结束(关闭浏览器)时,该会话对应的Session信息被删除。
3、Cookie有数量和大小的限制,Session没有或者说能支持非常大的数据量。
作用
Session与Cookie的作用都是为了保持访问用户与后端服务器的交互状态。
联系
1、Cookie需要Session
Cookie有着太多的缺点,需要Session来弥补。如数量限制,大小限制,安全性。
2、Session依赖于Cookie
Session保存了所有客户端访问服务端的会话信息,需要Cooekie中保存的JSESSIONID的值与Session中区分客户端的唯一ID对应,来让该客户端的所有访问能找到对应的Session信息。
深入了解Cookie
Cookie的属性项
1、NAME=VALUE:键值对,需要保存的信息写在这
2、Path:Cookie生成的路径
3、Domain:生成该Cookie的域名
4、Expires:过期时间
5、Secure:设置该属性后只会在SSH连接时才会回传该Cookie
例子:
"username=admin;password=000000;JSESSIONID=awi3pd0jf8504n;path=/;Domain=www.baidu.com;expires=Thu Jun 14 2018 01:52:21 GMT+0800"
注意:
1、用Cookie存数据时属性名不可以和Cookie自带的属性名相同
2、属性和值不能设置成非ASSIC字符
Cookie的相关操作
Cookie以字符串的形式保存
1、前端JS操作cookie:
// 读取cookie信息,如需某个属性值转换成数组遍历即可
var cookies=document.cookie;
// 声明一个字符串,字符串中为cookie的信息
var cookie1="username=admin";
// 添加cookie
document.cookie=cookie1;
// 修改cookie,给要改的属性重新赋值
document.cookie="username=linchen";
// 删除cookie,给cookie的过期时间重新赋值为昨天
document.cookie="expires="+(new Date()-1);
2、Java操作cookie:
JDK里javax.servlet.http.Cookie提供了cookie的API
Cookie的安全问题
Cookie就是不安全的!但是我们可以预防!
cookie存储数据一般遵循以下原则:
1、不要保存私人信息。
2、任何重要数据,最好通过加密形式来保存数据(最简单的可以用URLEncode,当然也可以用完善的可逆加密方式,遗憾的是,最好不要用md5来加密)。
3、是否保存登陆信息,需有用户自行选择。
4、长于4K的数据,不要用Cookies。
深入了解Session
Session如何工作
步骤:
- 浏览器访问网站(发起一个会话)
- 解析路径参数拿到seesion id
- 检查Cookie,如果Cookie中有session id,则覆盖之前的
- 运行到request.getSession()拿到该session id
- 根据id到sessions容器中查找已经存在的session对象
- 不存在则新建一个并添加到sessions容器中,存在则找到对应的session对象
- 返回Standard Session 对象
- 根据该对象的id新建一个Cookie,并将这个Cookie设置到Http协议头中
Session 操作
// 获取 Session 对象:
HttpSession session = requiest.getSession();
// 向HttpSession中保存数据;
session.setAttribute();
// 从HttpSession中获取数据;
session.getAttribute();
// 从HttpSession中移除数据;
session.removeAttribute();
// 返回HttpSession的唯一标识符;
session.getId();
// 设置session的存活时间(单位是秒),默认为30分钟;
session.setMaxInactiveInterval();
// 销毁HttpSession
session.invalidate();
※ 提示: (之前有说错)
javax.servlet.http.HttpSession类和javax.servlet.http.Cookie类
的jar包不在jdk里面,而tomcat的lib目录里面有,我们可以选择运行环境为tomcat来使用它们,也可以把这个jar包拷到项目里。
扩展(待以后补充)
分布式Session框架
- 需要一个服务订阅服务器
- ……
Session与Cookie的跨域共享
……
多终端Session统一
……
单点登录
单点登录原理与简单实现:
https://www.cnblogs.com/ywlaker/p/6113927.html
深入了解 Session 与 Cookie的更多相关文章
- 理解Session与Cookie
写在前面的话:Session和Cookie是非常有意思的两个概念,对于两者的管理可以处理的很复杂,但是无论如何,理解Session和Cookie的基本概念和发明初衷,对于问题的解决,大有裨益. === ...
- PHP之session与cookie
1.session与cookie的关系 众所周知,session是存储在服务器端,cookie是存储在客户端,如果禁用了浏览器的cookie功能,很多时候(除非进行了特殊配置)服务器端就无法再读取se ...
- 安全退出,清空Session或Cookie
概览: 网站中点击退出,如果仅仅是重定向到登录/出页面,此时在浏览器地址栏中输入登录后的某个页面地址如主页,你会发现不用登录就能访问.这种所谓的退出并不是安全的. 那么怎样做到安全退出呢? 那就是点击 ...
- 11月7日上午PHP会话控制(session和cookie)、跨页面传值
1.session 登录上一个页面以后,长时间没有操作,刷新页面以后需要重新登录. 特点:(1)session是存储在服务器: (2)session每个人(登陆者)存一份: (3)session ...
- 【荐】PHP Session和Cookie,Session阻塞,Session垃圾回收,Redis共享Session,不推荐Memcached保存Session
什么是 Session 在 web 应用开发中,Session 被称为会话.主要被用于保存某个访问者的数据. 由于 HTTP 无状态的特点,服务端是不会记住客户端的,对服务端来说,每一个请求都是全新的 ...
- Session与Cookie概念
摘:一.Session机制session是一种服务器端的状态管理技术,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存信息.当程序需要为某个客户端的请求创建一个session的时候,服务 ...
- session和cookie
第一次听到cookie这个词的时候着实兴奋了一段时间,以为是小饼干呢~快喝一杯82年的java压压惊!哈哈~ 与cookie的第一次邂逅——清缓存和清cookie 刚毕业的时候上班,做二次开发,明明后 ...
- 深入理解Session与Cookie
Session与cookie的作用都是为了保持访问用户与后端服务器的交互状态. cookie通过把所有要保存的数据通过HTTP协议的头部从客户端传递到服务端,又从服务端再传回到客户端,所有的数据都存储 ...
- TP中的session和cookie
session:1.session('name','value'); //设置session2.$value = session('name'); // 获取所有的session 3.2.2版本新 ...
- thinkphp里的session、cookie方法
thinkphp里,对于session和cookie的操作,不管是存值.获取.删除,均只有一个方法.现分享出来,供大家参考参考. /** * session管理函数 * @param string|a ...
随机推荐
- [py][mx]django实现课程机构排名
如果是第一次做这个玩意,说实话,确实不知道怎么弄, 做一次后就有感觉了 此前我们已经完成了: 分类筛选 分页 这次我们做的是 课程机构排名 知识点: - 按照点击数从大到小排名, 取出前三名 hot_ ...
- PAT 1138 Postorder Traversal [比较]
1138 Postorder Traversal (25 分) Suppose that all the keys in a binary tree are distinct positive int ...
- 本地blast的安装
1 下载程序 在ftp://ftp.ncbi.nlm.nih.gov/blast/executables/blast+/LATEST/下载 ncbi-blast-2.2.25+-x64-linux.t ...
- 禁止或强制使用堆分配---《C++必知必会》 条款34
有时候,指明一些特定类的对象不应该被分配到堆(heap)上是个好主意.通常这是为了确保该对象的析构函数一定会得到调用.维护对象本身(body object)的引用计数的句柄对象(handle obje ...
- 生成对抗网络(Generative Adversarial Network)阅读笔记
笔记持续更新中,请大家耐心等待 首先需要大概了解什么是生成对抗网络,参考维基百科给出的定义(https://zh.wikipedia.org/wiki/生成对抗网络): 生成对抗网络(英语:Gener ...
- uva1146 2-SAT问题
题意大白书 二分答案,然后对于每个可能的答案,跑一遍2-SAT就好了. #include <iostream> #include <string.h> #include < ...
- SQL: coalesce()函数
①用途: 将空值替换成其他值 返回第一个非空值 ②表达式: COALESCE是一个函数, (expression_1, expression_2, ...,expression_n)依次参考各参数表达 ...
- c++编译时打印宏定义
#pragma message("this is message") #pragma message只能打印字符串,如果想打印任何宏定义可使用: #define PRINT_MAC ...
- pyDay12
内容来自廖雪峰的官方网站. 1.可迭代对象(Iterable):可以直接作用于for循环的对象. 2.集合数据类型:如list.tuple.dict.set.str等. 3.generator:包括生 ...
- zabbix server监控报主机 Lack of free swap space
zabbix server监控报主机 Lack of free swap space,因为交换空间不足引起.该主机内存为3G,正常交换空间大小为物理内存2倍左右. #查看已有内存及交换空间 free ...