码迷,mamicode.com
首页 > 其他好文 > 详细

0011

时间:2020-02-16 01:38:27      阅读:101      评论:0      收藏:0      [点我收藏+]

标签:app   内容   默认   搜索   否则   中文字符   没有   ret   自动   

0011 Session与Cookie实现原理

第一节

会话管理

Cookie  保存在客户端

Session  保存在服务器内存中,客户端与服务器通讯用SessionId

应用场景在哪里? 登录,购物车,移动App接口会话管理

第二节 Cookie底层原理

1)服务器创建cookie对象,把会话数据存储到cookie对象中。

              new Cookie("name","value");

2)  服务器发送cookie信息到浏览器

                response.addCookie(cookie);

               举例: set-cookie: name=eric  (隐藏发送了一个set-cookie名称的响应头)

3)浏览器得到服务器发送的cookie,然后保存在浏览器端。

 4)浏览器在下次访问服务器时,会带着cookie信息

              举例: cookie: name=eric  (隐藏带着一个叫cookie名称的请求头)

 5)服务器接收到浏览器带来的cookie信息

                request.getCookies();

Cookie细节

1)void setPath(java.lang.String uri)   :设置cookie的有效访问路径。有效路径指的是cookie的有效路径保存在哪里,那么浏览器在有效路径下访问服务器时就会带着cookie信息,否则不带cookie信息。

                       

 2)void setMaxAge(int expiry) : 设置cookie的有效时间。

       正整数:表示cookie数据保存浏览器的缓存目录(硬盘中),数值表示保存的时间。

        负整数:表示cookie数据保存浏览器的内存中。浏览器关闭cookie就丢失了!!

        零:表示删除同名的cookie数据

3)Cookie数据类型只能保存非中文字符串类型的。可以保存多个cookie,但是浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。

第三节 Session技术

Cookie的局限:

1)Cookie只能存字符串类型。不能保存对象

2)只能存非中文。

3)1个Cookie的容量不超过4KB。

 如果要保存非字符串,超过4kb内容,只能使用session技术!!!

 Session特点:

      会话数据保存在服务器端。(内存中)

服务器创建一个Session后,session信息保存在服务器中,响应中把sessionId返回给客户端

客户端在下次请求中会将sessionId通过请求头的方式传给服务端

1)第一次访问创建session对象,给session对象分配一个唯一的ID,叫JSESSIONID
new HttpSession();
2)把JSESSIONID作为Cookie的值发送给浏览器保存
Cookie cookie = new Cookie("JSESSIONID", sessionID);
response.addCookie(cookie);
3)第二次访问的时候,浏览器带着JSESSIONID的cookie访问服务器
4)服务器得到JSESSIONID,在服务器的内存中搜索是否存放对应编号的session对象。
if(找到){
return map.get(sessionID);
}
Map<String,HttpSession>]


<"s001", s1>
<"s001,"s2>
5)如果找到对应编号的session对象,直接返回该对象
6)如果找不到对应编号的session对象,创建新的session对象,继续走1的流程

结论:通过JSESSION的cookie值在服务器找session对象!!!!!
3.4 Sesson细节
1)java.lang.String getId() : 得到session编号
2)两个getSession方法:
getSession(true) / getSession() : 创建或得到session对象。没有匹配的session编号,自动创 建新的session对象。
getSession(false): 得到session对象。没有匹配的session编号,返回null
3)void setMaxInactiveInterval(int interval) : 设置session的有效时间
session对象销毁时间:
3.1 默认情况30分服务器自动回收
3.2 修改session回收时间
3.3 全局修改session有效时间

 

0011

标签:app   内容   默认   搜索   否则   中文字符   没有   ret   自动   

原文地址:https://www.cnblogs.com/Baronboy/p/12315498.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!