<JavaWeb>Servlet-Cookie与Session

会话

会话可以认为是从用户打开客户端开始,到用户关闭客户端结束。会话中包含整个HTTP请求的过程。

会话使用

在会话的过程中,我们经常会遇到,例如偏好记录,自动登录,浏览记录等情况。为了让浏览器和服务器能够根据用户操作的数据,进行针对性的操作,我们需要让客户端或者服务器端保存用户的数据,这就要使用到Cookie和Session了。


Cookie:浏览器客户端

Cookie是一种会话数据,保存在客户端,以key-value的形式来保存数据,在服务器收到客户端的HTTP请求时,便会生成所需要的Cookie,保存在HTTP响应报文的头部中,浏览器接收到响应时,便会保存Cookie对象。当浏览器进行下一次请求时,会将Cookie保存在请求报文的头部,一并发给服务器。服务器再根据Cookie,做出响应的行为。

Cookie生命周期

如果我们不特意去设置失效时间,Cookie默认会在会话结束后失效(会话Cookie,一般保存在内存中)。
我们也可以使用setMaxAge来设置Cookie的有效期,这样Cookie就会被保存到硬盘上。
Cookie的生命周期是累积的,到期即会失效。

缺陷
  • 大小和数量限制
    Cookie由于是通过HTTP报文来传输的,所以存在着大小和数量的限制,一般每个站点可以保存20个Cookie,每个Cookie在4KB以内。
  • 数据安全性问题
    HTTP请求中的Cookie是明文传输的,所以会有泄漏信息的危险。
使用范例
//如果是第一次连接,从报文中获取信息
String userName = request.getParameter("key");
//创建Cookie并装入响应报文
Cookie userName = new Cookie("key", "value");
userName.setMaxAge(2*60);//两分钟
response.addCookie(userName);

//获取Cookie
Cookie[] cookies = request.getCookies();
//判断是否为第一次访问,如果不是,做判断
if(cookies != null)
{
    for(Cookie cookie : cookies)
    {
        //与数据库中的对应信息匹配
        if(cookie.getName().equals("key"))
        {
            userName = cookie.getValue();
        }
    }
}

HttpSession:服务器端

HttpSession是服务器端为客户端创建的一个对象,保存着用户的数据,用于服务器端和客户端状态保存。

服务器端在接收到客户端的请求之后,创建一个拥有唯一编号的Session对象,并将相应的数据保存进这个对象中,接着服务器端将Session的唯一编号放在Cookie中,发送回浏览器端。

当浏览器再次访问时,服务器就会根据Session Id,取出对应的Session对象,进行个性化的响应。Session的默认有效期是30分钟,我们可以通过setMaxInactiveInterval接口或者配置部署描述符来设置Session的有效期。接口配置的有效期优先级更高。

与Cookie不同的是,Session保存在服务器端,我们可以通过调用invalidate来使对应的Session主动失效。

使用范例
//如果是第一次连接,从报文中获取信息
String userName = request.getParameter("key");
//创建HttpSession对象,当用户第一次访问时,没有Session对象,这样就会默认创建一个Session对象。
HttpSession session = request.getSession();
session.setAttribute("userName", userName);
session.setMaxInactiveInterval(2*60);//两分钟
//session. invalidate();//session失效
//二次请求时,可以拿到Session对象中的值
String name = (String)session.getAttribute("userName");
if(name != null)
{
    //do Something
}

部署描述符:
描述符与<servlet>同层次

<session-config>
    <session-timeout>2</session-timeout>//单位为分钟
</session-config>

与Cookie不同的是,Session的生命周期是间隔的,从最后一次访问开始算,过期失效。
由于Session是存放在服务器内存中的,过多的访问量会大量占据服务器资源,因此,不建议存放大量数据在Session中。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容