JavaWeb总结(七)

Web状态管理

  - HTTP协议使用的是无状态的连接

  - 对容器而言,每一个请求都来自于一个新的客户

解决方案-表单隐藏字段

<input type=”hidden” name=”session” value=”...”>

 该项表单内容在提交表单时,指定的名称和值将包含在Get和Post数据中。隐藏字段不会呈现给用户的页面外观,相反,它们可以存储固定发送给服务器的固定名称和值,而不管用户输入如何。有如下用途:

  - 对用户在网站上的访问进行会话跟踪。

  - 为服务器端程序提供预定义的输入。

  - 存储动态产生的页面上下文信息。

  缺点:只有当每个页面都是动态生成的时候才会有效

使用隐藏字段进行会话跟踪

解决方案-Cookie

  Cooike是Web服务器发送到客户端浏览器的简讯文本信息,在第一次访问服务器后就由服务器向客户端浏览器发送,以后在访问同一个Web站点或域时,浏览器就会毫无更改地返回该文本信息。通过让服务器来读取以前发送到客户端的信息,Web应用程序就能够为访问者提供许多方便。

HTTP Cookie的解决方案

- 用Cookie保存值

//实例化一个Cookie,以键值对的形式存放
Cookie cookie = new Cookie(key,value);
//重新设置Cookie的值
cookie.setValue(newValue);
//设置Cookie的生命周期
//值为正数表示为多少秒后清除cookie,0表示立即清楚cookie
//若为负值表示关闭浏览器后清除cookie
cookie.setMaxAge(second);
//把Cookie返回给响应
response.addCookie(cookie);

- 获取Cookie中的值

//获取请求中的Cookie
Cookie[] cookies = request.getCookie();
//遍历取出Cookie中的键值对
For(Cookie cookie:cookies){
    String key = cookie.getName();
    String value = cookie.getValue();
    //获取之后对值进行操作的代码
}

解决方案-URL重写

  当浏览器不支持Cookie或者禁用Cookie时,就可以使用URL地址重写。但是服务器端程序需要为此完成很多简单却又繁琐的处理过程,因为引用站点并返回给用户的每个URL,甚至通过服务器重定向的方式,都追加了额外的信息。

URL重写解决方案

Session原理

  - 服务器可以为客户端创建并维护一个Session对象,用于存放数据。

  - 在创建Session对象的同时,服务器将会为该 Session对象产生一个唯一编号,这个编号称之为SessionID

  - 服务器以Cookie的方式将SessionID存放在客户端。

  - 当浏览器再次访问该服务器时,会将SessionID作为Cookie信息带到服务器,服务器可以通过该SessionID检索到以前的Session对象,并对其进行访问

Session的工作流程

Session会话跟踪机制

  - 用户发送请求

//从请求中获取session对象
HttpSession session = request.getSession();

  - 服务器的响应如下

  //HTTP的响应信息

  - 再次发送请求

HttpSessoin接口

  HttpSession是Java平台对Session机制的实现规范,因为它仅仅是个接口,具体由每个web应用服务器的提供商实现。一般情况下Session都是存储在内存里,当服务器进程被停止或重启的时候,内存里的Session也会被清空(Session对象占用着系统资源)。

  - setAttribute(java.lang.String, java.lang.Object):在Session对象中用一个名字绑定一个对象。

  - getAttribute(java.lang.String):通过名字获取Session对象中保存的对象。

- removeAttribute(java.lang.String):在Session中删除与一个名字对应的对象。

- getCreationTime():返回第一次创建会话的时间。

- getLastAccessedTime():返回容器最后一次得到该会话ID的请求时间。

- setMaxInactiveInterval(int interval):对于会话指定客户请求的最大间隔时间,以秒为单位。-1表示永不过期

- getMaxInactiveInterval(int interval):返回客户请求的最大间隔时间。

- invalidate():会话结束,当前存在在会话中的所有会话属性也会解除绑定。

- getId():此方法返回每个session唯一的标识

会话超时管理

  销毁Session可以采用的简单方式

- 设置会话超时。

- 在Session对象上调用invalidate()方法。

- 应用结束(崩溃或取消部署)

在web.xml文件中配置

<session-config>

    <session-timeout>15</session-timeout>

</session-config> 

提示:在web.xml文件中指定会话超时时间,是以分钟为单位。在程序中设置时间是以秒为单位。

Application与Session域范围的属性比较

- 在web应用上下文域范围和Session域范围中,都可以用一个名字来绑定一个对象,从而在域范围内进行访问

- 绑定在Session范围内的对象仅仅在一个持续的会话期间被维护

- 绑定在Application(应用上下文)中的对象,在整个Web应用程序运行过程中都被维护

-都使用相同的方法:setAttribute()和getAttribute()


提示:在Application应用范围内保存的对象,维护时间要比在Session域范围内保存的对象长,但是都要占用服务器系统资源,应当尽量使用维护时间短的域对象,或者在不使用后利用removeAttribute()方法销毁绑定对象。

Session持久化管理

  Session对象的信息一般情况下置于服务器的内存中,当服务器由于故障重启,或者Web应用重新加载的时候,此时的Session信息将会全部丢失。为了避免这样的情况,在某些场合可以将服务器的Session数据存放在文件系统或数据库中,这样的操作称为Session对象的持久化。Session对象在持久化时,存放在其中的对象以序列化的形式存放,这就是为什么一般存放在Session中的数据需要实现可序列化接口(java.io.Serializable)的原因;

  通过Context元素的子元素Manager配置Session管理对象:

- ClassName属性用于指定管理Session的类可以是StandarManager或PersitentManager。

- maxActiveSession表示允许存在最多活动Session对象的数目,-1表示不限制。

- maxInactiveInterval表示Session的默认的最长不活动间隔,单位为秒。

- pathname表示StandarManager在服务器重启或应用重新加载时持久化Session对象的文件名,如果设置为"",相当于关掉了Session的持久化机制。

URL重写

- Session对象的正常使用要依赖于Cookie

  - URL地址重写能够取得置于Cookie中的会话,并把会话ID附加到访问应用的各个URL最后

  URL重写的方法(把SessionID附加到URL地址后面)

- response.encodeURL();

- response.encodeRedirectURL("/lovobook/otherServlet");


提示:静态HTML页面不能实现URL重写,因为URL附加内容必须动态生成。

并且使用URL编码后,容器会首先尝试使用Cookie完成会话管理,只有当Cooike方法失败时才会使用URL重写。

时间: 2024-11-08 20:22:52

JavaWeb总结(七)的相关文章

JavaWeb结合七牛云存储搭建个人相册

JavaWeb结合七牛云存储搭建个人相册 一.引言 1. 课程概述 相信很多人都知道网站一般会有很多图片,对于小型网站来说,图片放在网站服务器上不算什么,但当图片数量很大时,会造成服务器很臃肿,相应地对带宽要求也会提高,这就造成了成本的增加.其实现在已经流行云存储,我们可以把图片.大文件等放到第三方提供的云存储服务上,这会减少一部分成本.这门课程就介绍了JavaWeb结合七牛云存储来搭建个人相册服务. 2. 预备知识 掌握Servlet+JSP,能了解Bootstrap更好. 二.Just Do

JavaWeb结合七牛云存储搭建个人相册服务

JavaWeb结合七牛云存储搭建个人相册服务 一.引言1. 课程概述 相信很多人都知道网站一般会有很多图片,对于小型网站来说,图片放在网站服务器上不算什么,但当图片数量很大时,会造成服务器很臃肿,相应地对带宽要求也会提高,这就造成了成本的增加.其实现在已经流行云存储,我们可以把图片.大文件等放到第三方提供的云存储服务上,这会减少一部分成本.这门课程就介绍了JavaWeb结合七牛云存储来搭建个人相册服务. 2. 预备知识 掌握Servlet+JSP,能了解Bootstrap更好. 二.Just D

JavaWeb(七)Cookie,EL表达式,标准标签库

Cookie Cookie概述 Cookie译为小型文本文件或小甜饼,Web应用程序利用Cookie在客户端缓存服务器端文件.Cookie是以键值对形式存储在客户端主机硬盘中,由服务器端发送给客户端,客户端再下一次访问服务器端时,服务器端可以获取到客户端Cookie缓存文件. Cookie是由服务器端创建的,然后由服务器端发送给客户端,客户端以键值对形式存储Cookie,并标注Cookie的来源.客户端再次访问服务器端时,存储的Cookie会保存在请求协议中,服务器端可以获取上次存储的缓存文件内

JavaWeb(七)JSP-2

1.JSP指令简介 JSP指令(directive)是为JSP引擎而设计的,它们并不直接产生任何可见输出,而只是告诉引擎如何处理JSP页面中的其余部分. JSP指令的基本语法格式: <%@ 指令 属性名="值" %> 举例:<%@ page contentType="text/html;charset=gb2312"%> 注意:属性名部分是大小写敏感的 在目前的JSP 2.0中,定义了page.include和taglib这三种指令,每种指令

mybatis初级映射

一 前言 系统学习知识请认准知识追寻者(同公众号),错过作者,你有可能要走好多弯路 经过第一篇的入门文章,小白们都对mybatis的搭建流程应该都很熟悉,这篇文章主讲的是如何使用mybatis实现数据库的增删改查,以及相关的标签属性.配置说明,可以说这篇文章是为你以后的学习和工作打下坚实基础文章,小白们要认真看,认真敲,下面是准备的sql语句.此文强到没朋友!!!! CREATE TABLE `course` ( `courseName` varchar(255) DEFAULT NULL CO

项目ITP(七) javaWeb 整合 Quartz 实现动态调度 并且 持久化

项目ITP(七) javaWeb 整合 Quartz 实现动态调度 并且 持久化 原创地址:http://www.cnblogs.com/Alandre/(泥沙砖瓦浆木匠),需要转载的,保留下! 弟子规 圣人训 首孝弟 次谨信 泛爱众 而亲仁 有余力 则学文 Written In The Font 需要:WEB-INF/lib/quartz-2.2.1.jar 基本步骤: web.xml注册监听器ScheduleStartListener 监听器类sedion.jeffli.wmuitp.lis

JavaWeb快速入门Session&amp;Cookie代码思路篇(七)

Cookie练习 简介 尝试了n种分享代码,最终没有找到好办法.我觉得贴代码,很难看下去.还不如写思路,今后代码篇改成思路篇 Session代码练习 1. 购物车思路 1. ListBookServlet类 1.1 显示该网站所有商品,每个商品加上购买链接(BuyServlet) 用Map集合存储Book对象 map.put("1", new Book("1","JavaWeb开发","老张","一本好书"

javaweb学习总结(七)——HttpServletResponse对象(一)

Web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对象.和代表响应的response对象.request和response对象即然代表请求和响应,那我们要获取客户机提交过来的数据,只需要找request对象就行了.要向客户机输出数据,只需要找response对象就行了. 一.HttpServletResponse对象介绍 HttpServletResponse对象代表服务器的响应.这个对象中封装了向客户端发送数据.发送响应头,发送响应状态码的方法.查

JavaWeb学习笔记——开发动态WEB资源(七)

该工程的功能是实现一个bookapp 1.开发注册页面,注册使用properties文件,存储在classpath跟路径 2.注册成功跳转到登录页面 3.输入用户名密码登录,登录成功跳转到book显示页面 4.开发持久化对象Course.java,用来存储持久化数据 5.开发DAO对象,即数据访问对象,提供获得所有课程的方法 6.在bookServlet里面获得调用DAO对象的方法获取所有课程 7.循环显示

javaweb学习总结(七)——HttpServletResponse对象(一)(转)

Web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对象.和代表响应的response对象. request和response对象即然代表请求和响应,那我们要获取客户机提交过来的数据,只需要找request对象就行了.要向客户机输出数据,只需要找response对象就行了. 一.HttpServletResponse对象介绍 HttpServletResponse对象代表服务器的响应.这个对象中封装了向客户端发送数据.发送响应头,发送响应状态码的方法.