会话和会话状态
WEB应用中的会话是指一个客户端浏览器与WEB服务器之间连续发生的一系列请求和响应过程。
WEB应用的会话状态是指WEB服务器与浏览器在会话过程中产生的状态信息,借助会话状态,WEB服务器能够把属于同一会话中的一系列的请求和响应过程关联起来。
如何实现有状态的会话:
需要浏览器对其发送出每个请求消息都进行标识(并且附带标识号称之为会话ID(SessionID))
Cookie机制
- cookie机制采用的是在客户端保持HTTP状态信息的方案
- Cookie是在浏览器访问WEB服务器的某个资源时,由WEB服务器在HTTP响应消息头中附带传送给浏览器的一个小文本文件。
- 一旦WEB浏览器保存了某个Cookie,那么他在以后每次访问该WEB服务器时,都会在HTTP请求头中将这个Cookie回传给WEB服务器。
- 底层实现原理:WEB服务器通过在HTTP响应消息中增加Set-Cookie响应投资段将Cookie信息发送给浏览器,浏览器则通过在HTTP请求消息中增加Cookie请求头字段将Cookie回传给WEB服务器。
在Servlet程序中使用Cookie
- Servlet API中提供了一个javax.servlet.http.Cookie类来封装Cookie信息,它包含有生成Cookie信息和提取Cookie信息的各个属性的方法。
- Cookie类的方法:
- 构造方法:public Cookie (String name,String value)
- getName()方法
- setValue()与getValue()方法
- setMaxAge与getMaxAge方法
- setPath与getPath方法
- HttpServletResponse接口中定义了一个addCookie方法,它用于在发送给浏览器的HTTP响应消息中增加一个Set-Cookie响应头字段
- HttpServletResponse接口中定义了一个getCookie方法,它用于从HTTP请求消息的Cookie请求头字段中读取所有的Cookie项。
<% //在JavaWeb规范中使用Cookie类代表Cookie //1.创建一个Cookie对象 Cookie cookie = new Cookie("yang","yhs"); //2.调用response的一个方法把Cookie传给客户端 response.addCookie(cookie); %>
<% //1.获取Cookie Cookie [] cookies = request.getCookies(); response.setContentType("charset=UTF-8"); if (cookies!=null&&cookies.length>0){ for (Cookie cookie : cookies){ out.print(cookie.getName() + ":" + cookie.getValue()); out.print("<br>"); } }else{ out.print("没有一个Cookie,正在创建并返回"); //在JavaWeb规范中使用Cookie类代表Cookie //1.创建一个Cookie对象 Cookie cookie = new Cookie("yang","yhs"); //2.调用response的一个方法把Cookie传给客户端 response.addCookie(cookie); } %>
Cookie的发送
1.创建Cookie对象
2.设置最大时效
3.将Cookie放入到HTTP响应报头
- 如果创建一个Cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie,存储在浏览器的内存中,用户退出浏览器之后被删除。若希望浏览器将该cookie存储在磁盘上,则需奥使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。