Day10_19——HttpSession

1、HttpSession概述

  • HttpSession时由JavaWeb提供的,用来会话跟踪的类。Session是服务器端对象,保存在服务器端!

  • HttpSession是Servlet三大域对象之一(request(一个请求一个request)、session(一个用户一个session)、application(ServletContext))。所有HttpSession也有setAttribute()、getAttribute()、removeAttribute()。

  • HttpSession底层依赖Cookie,或是URL重写!

2、HttpSession的作用

  • 会话范围:会话范围是某个用户从首次访问服务器开始,到该用户关闭浏览器结束!

会话:一个用户对服务器的多次连贯性请求!所谓连贯性请求,就是该用户多次请求中间没有关闭的浏览器。

  • 服务器会为每个客户端创建一个session对象,session就好比客户在服务器端的账户,它们被服务器保存到一个Map集合中,这个Map被称之为session缓存

Servlet中得到session对象:HttpSession session = rerquest.getSession();

Jsp中得到session对象:session是jsp内置对象之一,不用创建就可以直接使用。

  • session域的相关方法:

void setAttribute(String name, Object value);

Object getAttribute(String name);

void removeAttribute(String name);

案例一:在session域中保存和获取数据

a.jsp


<body>

    <h1>保存数据到session域中</h1>

<%

session.setAttribute("aaa", "AAA");

%>

  </body>

b.jsp

<body>

<h1>获取session域中的数据</h1>

<%

String s = (String) session.getAttribute("aaa");

%>

<%=s%>

</body>

总结:在保存数据之后,只要不关闭浏览器就可以获取到session中的数据。IE浏览器中的新建会话除外。再打开一个相同的浏览器也是可以获取到的。

案例二:演示保存用户登录信息(精通)

案例.jpg

Login.jsp

<script type=*"text/javascript"*>

**function** _change(){

/*

1.得到img元素

2.修改其src为/SessionDemo/VeifyCodeServlet

*/

**var** imgEle = document.getElementById("img");

**var** v = **new** Date;

**var** s = v.getTime();

//imgEle.src = "/SessionDemo/VeifyCodeServlet?a=" + new Date().getTime();

imgEle.src = "/SessionDemo/VeifyCodeServlet?a=" + s;

}

</script>

</head>

<body>

<h1>登录</h1>

<%

/*

读取名为uname的cookie,如果为空显示"",不为空显示cookie的值

 */

String uname = "";

Cookie[] cs = request.getCookies(); // 获取请求中所有的cookie

**if**(cs != **null**){ // cookie不为空

**for**(Cookie c : cs){ // 循环遍历Cookie[]

**if**("uname".equals(c.getName())){ // 查找名称为uname的cookie

uname = c.getValue(); // 将值赋给uname变量

}

}

}

%>

<%

String s = "";

String msg = (String) request.getAttribute("msg");

**if**(msg != **null**) {

s = msg;

}

%>

<%-- 本页面提供登录表单,还要显示错误信息 --%>

<font color=*"red"*><b><%=s%></b> </font>

<form action=*"/SessionDemo/LoginServlet"* method=*"post"*>

用户名:<input type=*"text"* name=*"username"* value=*"*<%=uname%>*"* /><br /> 

密码:<input type=*"password"* name=*"password"* /><br /> 

验证码:<input type=*"text"* name=*"vCode"*  size=*"3"*/>

<img  id=*"img"* src=*"/SessionDemo/VeifyCodeServlet"*>

<a href=*"javascript: _change()"*>看不请,换一张</a>

<br />

<input type=*"submit"* value=*"登录"* />

</form>

</body>
**VeifyCodeServlet****.java**

**public** **void** doGet(HttpServletRequest request, HttpServletResponse response)

**throws** ServletException, IOException {

/*

 * 1.生成图片(用到了VerifyCode生成验证码的类)

 * 2.保存图片上的文本到session中

 * 3.把图片响应给客户端

 */

VerifyCode vc = **new** VerifyCode();

BufferedImage bi = vc.getImage();

request.getSession().setAttribute("session_vcode", vc.getText());

vc.*output*(bi, response.getOutputStream());

}

LoginServlet.java


**public** **void** doPost(HttpServletRequest request, HttpServletResponse response)

**throws** ServletException, IOException {

/*

 * 验证码处理 1.得到session里的验证码文本 2.获取到文本框中输入的文本 3.比较

 */

String <u>sessiontext</u> = (String) request.getSession().getAttribute(

"session_vcode");

String wtext = request.getParameter("vCode");

**if** (!wtext.equalsIgnoreCase(sessiontext)) {

request.setAttribute("msg", "输入的验证码有误");

request.getRequestDispatcher("/session2/login.jsp").forward(

request, response);

**return**;

}

/*

 * 1、获取表单信息

 */

// 中文处理

request.setCharacterEncoding("utf-8");

// 获取

String username = request.getParameter("username");

String <u>password</u> = request.getParameter("password");

/*

 * 2、校验用户名和密码是否正确

 */

**if** (!"itcast".equalsIgnoreCase(username)) {

// 成功

/*

 * 附加项:把用户名保存到cookie中,发送给客户端浏览器

 * 当再次打开login.jsp时,login.jsp会读取request中的cookie,把它显示到用户名文本框中

 */

Cookie cookie = **new** Cookie("uname", username);// 创建cookie

cookie.setMaxAge(60*60*24);// 设置cookie名长为一天

response.addCookie(cookie);// 保存cookie

/*

 * 3、如果成功 > 保存用户信息到session中 > 重定向到succ1.<u>jsp</u>

 */

HttpSession session = request.getSession();// 获取session对象

session.setAttribute("username", username);// 向session域中保存数据

response.sendRedirect("/SessionDemo/session2/succ1.jsp");

} **else** {

// 失败

/*

 * 4、如果失败 > 保存错误数据到request域中 >

 * 转发到login.jsp(如果使用重定向request域中的数据就会因为第二次请求 而获取不到)

 */

request.setAttribute("msg", "用户名或密码错误");

RequestDispatcher rd = request

.getRequestDispatcher("/session2/login.jsp");

rd.forward(request, response);// 转发

}

}

succ1.jsp

<body>

<%

String username = (String)session.getAttribute("username");

**if**(username==**null**){

/*

 *  向request域中保存错误信息,并转发到login.jsp

 */

request.setAttribute("msg", "你还没有登录");

request.getRequestDispatcher("/session2/login.jsp").forward(request, response);

**return**;

}

%>

<h1>succ1</h1>

欢迎<%=username %>访问本页面。

</body>

Succ2.jsp

<body>

<%

String username = (String)session.getAttribute("username");

**if**(username==**null**){

/*

 *  向request域中保存错误信息,并转发到login.jsp

 */

request.setAttribute("msg", "你还没有登录");

request.getRequestDispatcher("/session2/login.jsp").forward(request, response);

**return**;

}

%>

<h1>succ1</h1>

欢迎<%=username %>访问本页面。

</body>

3、HttpSession的原理(银行卡的用法相同)

  • request.getSession()的方法:

获取Cookie中的JSESSIONDID:

(服务器不会马上创建session,在第一次获取时才会创建——request.getSession();)

<> 如果sessionID不存在,创建session,把session保存起来,把新创建的session保存到Cookie中

<> 如果sessionID存在,通过sessionID查找session对象,如果没有查到,创建session,把session保存起来,把新创建的sessionID保存到Cookie中

<> 如果session存在,通过sessionID找到了session对象,那么就不会再创建session对象了。

<> 返回session。

如果创建了新得session,浏览器会得到一个包含了sessionID的Cookie,这个Cookie的生命是-1(在浏览器中存在)

  • request.getSession(false) request.getSession(ture) request.getSession() 后两个效果一样

第一个方法:如果session缓存中,不存在session,那么返回null,而不会返回session对象

4、HttpSession的其他方法(用最多的还是session的域方法)

  • String getID():获取sessionID;(UUID随机生成32位16进制数)

  • int getMaxInactiveInterval():获取session可以的最大活动时间(秒),默认位30分钟(一般不写)

  • void invalidate():让session失效!(可以用来做退出效果)

  • Boolean isNew():查看session是否为新。

request.getSession().isNew(); 可以检验是创建session还是返回session

5、在web.xml中配置session的最大活动时间

<session-config>

<session-timeout>时间(分)</session-timeout>

</session-config>

6、URL重写(理解)

就是把所有页面中的路径,都使用response.encode URL(“....路径....”)处理一下

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