0011

Posted baronboy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了0011相关的知识,希望对你有一定的参考价值。

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的主要内容,如果未能解决你的问题,请参考以下文章

0011 - YARN核心设计解析

python每日一练:0011题

lesson0011 作业

20170513 Python练习册0011过滤敏感词

20170513 Python练习册0011替换敏感词

0011vmware网络配置