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

session

时间:2016-08-08 17:31:17      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:

Session:在计算机中,尤其是在网络应用中,称为“会话控制”。Session 对象存储特定用户会话所需的信息。这样,当用户在应用程序的 Web 页之间跳转时,存储在 Session 对象中的变量将不会丢失,而是在整个用户会话中一直存在下去。
会话状态仅在支持 cookie 的浏览器中保留。

我用django登录我的user,登录进去,写入user信息到session当中,我在服务器的信息可以通过session_id来访问session里面存储的user信息,如果session_id不存在,那么用户没有登录

session并不能在调试模式(Debug mode)下正常工作,这是因为session与调试模试下的重调用相冲突(有点类似firefox下著名的Firebug插件,使用Firebug插件分析网页时,会在火狐浏览器之外单独对该网页发起请求,所以相当于同时访问该网页两次)

session基础
会话允许每个访问者存储任意数据,这个数据下次访问者访问该网站。 
Session代表服务器与浏览器的一次会话过程,这个过程是连续的,也可以时断时续的。


session是存储在服务端的信息,cooike是保存在客户端的信息
8、session是一个容器,可以存放会话过程中的任何对象。
session因为请求(request对象)而产生,同一个会话中多个request共享了一session对象,可以直接从请求中获取到session对象。
session存放在cookie当中,在服务器通过session的算法生成session_id返回给客户端,客户端再通过session_id进行访问

session的创建和使用总在服务端,而浏览器从来都没得到过session对象。但浏览器可以请求Servlet(jsp也是Servlet)来获取session的信息。客户端浏览器真正紧紧拿到的是session ID
通过session_id来获取session对象

2)、当JSP页面没有显式禁止session的时候,在打开浏览器第一次请求该jsp的时候,服务器会自动为其创建一个session,并赋予其一个sessionID,发送给客户端的浏览器。以后客户端接着请求本应用中其他资源的时候,会自动在请求头上添加:
Cookie:JSESSIONID=客户端第一次拿到的session ID
这样,服务器端在接到请求时候,就会收到session ID,并根据ID在内存中找到之前创建的session对象,提供给请求使用。



下面是两次请求同一个jsp,请求头信息:
技术分享技术分享
通过图可以清晰发现,第二次请求的时候,已经添加session ID的信息。


3、Session删除的时间是:
1)Session超时:超时指的是连续一定时间服务器没有收到该Session所对应客户端的请求,并且这个时间超过了服务器设置的Session超时的最大时间。
2)程序调用HttpSession.invalidate()
3)服务器关闭或服务停止
 
4、session存放在哪里:服务器端的内存中。不过session可以通过特殊的方式做持久化管理。

session的id是从哪里来的,sessionID是如何使用的:当客户端第一次请求session对象时候,服务器会为客户端创建一个session,并将通过特殊算法算出一个session的ID,用来标识该session对象,当浏览器下次(session继续有效时)请求别的资源的时候,浏览器会偷偷地将sessionID放置到请求头中,服务器接收到请求后就得到该请求的sessionID,服务器找到该id的session返还给请求者(Servlet)使用。一个会话只能有一个session对象,对session来说是只认id不认人。

6、session会因为浏览器的关闭而删除吗?
不会,session只会通过上面提到的方式去关闭。














session

标签:

原文地址:http://www.cnblogs.com/wuqingzangyue/p/5749801.html

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