cookie和sessiong

1.会话技术

用户在访问的时候,会产生一些数据,这些数据存在时间上的因果关系,即下一次的访问,有可能会用到上一次的访问数据,但是http协议是一个无状态的协议,所以,这些数据将通过会话技术进行保存。

当用户访问服务器资源开始,到关闭浏览器,可以视为一次会话。会话可以分为cookie和session,其中,cookie是浏览器端的会话技术,session是浏览器端的会话技术

2.cookie

(1)cookie的流程

当浏览器访问服务器时,服务器产生cookie,然后通过respond将cookie写回到浏览器中,下次浏览器再访问服务器的时候,将cookie按照一定的规则发送到服务器

(2)服务器端cookie

新建cookie:Cookie cookie = new Cookie(String key, String value);

浏览器写回cookie:respond对象.addcookie(Cookie c);

服务器获取cookie:Cookie[] request对象.getCookies();

Cookie对象方法:getName();获取cookie的key

                             getValue();获取指定cookie的value

                             setMaxAge(Int s); 设置cookie在浏览器存活的时间,单位秒,如果设置为0,表示删除该cookie

                             setPath(String path);设置cookie的路径,如果浏览器访问的资源包含了此cookie的路径,那么携带该cookie请求

路径可以由request.getContextPath()得到项目路径

3.session

session是服务器端的会话技术,他将我们访问服务器时的数据保存,用来存放私有数据

session与cookie的作用过程:

(1)浏览器访问服务器,服务器获取cookie携带的jsessionid

(2)若获取不到jsessionid,则创建一个session,然后将session的jsessionid通过cookie返回

(3)若获取到jsessionid,则去session池中查找是否有该session

a.若有,则直接使用

b.若没有,则创建session,然后将session的jsessionid通过cookie返回

注意:jsessionid是浏览器通过cookie直接返回的,不需要手工进行操作

获取session:HttpSession request.getSession();

域对象:xxxAttribute,其生命周期为:

创建:第一次调用reqquest.getSession()

销毁:服务器非正常关闭

                   session超时:默认为30min,web.xml中可以配置

                                          手动设置超时:setMaxInactiveInterval(int s)

                   手动销毁session:session.invalidate()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值