JSP会话Session跟踪
在本章中,我们将讨论JSP中的会话跟踪。 HTTP是一种“无状态”协议,这意味着每次客户端检索一个Web页面时,客户机打开与Web服务器的单独连接,并且服务器自动不保留先前客户端请求的任何记录。
维护Web客户端与服务器之间的会话
现在来讨论几个用来维护Web客户机和Web服务器之间会话的方式 -
1.Cookies
网络服务器可以将唯一的会话ID作为cookie分配给每个Web客户端,并为客户端提供后续请求,并使用接收到的cookie进行识别。
这可能不是有效的方式,因为浏览器有时不支持cookie。不建议使用此过程来维护会话。
2.隐藏表单字段
Web服务器可以发送隐藏的HTML表单域以及唯一的会话ID,如下所示:
<input type = "hidden" name = "sessionid" value = "123456">
当提交表单时,指定的名称和值将自动包含在GET
或POST
数据中。 每次Web浏览器发送请求时,session_id
值都可以用于跟踪不同的Web浏览器。
这可以是跟踪会话的有效方法,但点击常规(<a href="...">
)超文本链接不会产生表单提交,因此隐藏表单字段也不能支持常规会话跟踪。
3.网址重写
可以在每个网址的末尾附加一些额外的数据。该数据标识会话; 服务器可以将该会话标识符与其关于该会话存储的数据相关联。
例如,使用URL:http://www.zyiz.net/file.html;sessionid=123456789
,会话标识符作为sessionid=123456789
附加,可以在Web服务器上访问以识别客户端。
URL重写是一种更好的方法来维护会话,并且在浏览器不支持cookie时可以使用它们。 这里的缺点是,必须动态生成每个URL来分配会话ID,而页面是一个简单的静态HTML页面。
4.session对象
除了上述选项之外,JSP还使用了提供HttpSession
接口的servlet。该接口提供了一种识别用户的方法。
- 一个页请求或
- 访问网站或
- 存储有关该用户的信息
默认情况下,JSP启用会话跟踪,并为每个新客户端自动实例化一个新的HttpSession
对象。 禁用会话跟踪需要通过将页面指令会话属性设置为false
来明确地将其关闭,如下所示:
<%@ page session = "false" %>
JSP引擎通过隐式会话对象将HttpSession
对象公开给JSP程序员。由于会话对象已经提供给JSP程序员,程序员可以立即开始从对象中存储和检索数据,而无需任何初始化或getSession()
。
以下是session
对象提供的重要方法列表 -
编号 | 语法 | 描述 |
---|---|---|
1 | public Object getAttribute(String name) |
此方法返回在此会话中用指定名称绑定的对象,如果在名称下没有绑定对象,则返回null 。 |
2 | public Enumeration getAttributeNames() |
此方法返回一个包含绑定到此会话的所有对象的名称的String 对象枚举。 |
3 | public long getCreationTime() |
此方法返回创建此会话的时间,以1970年1月1日GMT格林尼治时间以来的毫秒为单位。 |
4 | public String getId() |
此方法返回一个包含分配给此会话的唯一标识符的字符串。 |
5 | public long getLastAccessedTime() |
此方法返回客户端上次发送与此会话相关联的请求的时间,为1970年1月1日GMT以来的毫秒数。 |
6 | public int getMaxInactiveInterval() |
此方法返回servlet容器在客户端访问之间保持此会话的最长时间间隔(以秒为单位)。 |
7 | public void invalidate() |
此方法使该会话无效,并取消绑定绑定到该对象的任何对象。 |
8 | public boolean isNew() |
如果客户端还不知道会话或者客户端选择不加入会话,则此方法返回true 。 |
9 | public void removeAttribute(String name) |
此方法从此会话中删除与指定名称绑定的对象。 |
10 | public void setAttribute(String name, Object value) |
此方法使用指定的名称将对象绑定到此会话。 |
11 | public void setMaxInactiveInterval(int interval) |
此方法指定在servlet容器将使此会话无效之前,客户端请求之间的时间(以秒为单位)。 |
会话跟踪示例
此示例介绍如何使用HttpSession
对象来查找会话的创建时间和最后访问的时间。如果尚不存在,会将新建会话与请求相关联。
打开Eclipse,创建一个动态Web项目:SessionTracking, 其目录结构如下所示 -
创建一个JSP文件:index.jsp,如下代码 -
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="java.io.*,java.util.*"%> <% // Get session creation time. Date createTime = new Date(session.getCreationTime()); // Get last access time of this Webpage. Date lastAccessTime = new Date(session.getLastAccessedTime()); String title = "Welcome Back to my website"; Integer visitCount = new Integer(0); String visitCountKey = new String("visitCount"); String userIDKey = new String("userID"); String userID = new String("ABCD"); // Check if this is new comer on your Webpage. if (session.isNew()) { title = "Welcome to my website"; session.setAttribute(userIDKey, userID); session.setAttribute(visitCountKey, visitCount); } visitCount = (Integer) session.getAttribute(visitCountKey); visitCount = visitCount + 1; userID = (String) session.getAttribute(userIDKey); session.setAttribute(visitCountKey, visitCount); %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Session会话跟踪示例</title> </head> <body> <div style="margin: auto; width: 80%;"> <center> <h2> Session会话跟踪示例 </h1> </center> <table border="1" align="center"> <tr bgcolor="#949494"> <th>会话信息</th> <th>值</th> </tr> <tr> <td>id</td> <td> <% out.print(session.getId()); %> </td> </tr> <tr> <td>创建时间</td> <td> <% out.print(createTime); %> </td> </tr> <tr> <td>最近一次访问时间</td> <td> <% out.print(lastAccessTime); %> </td> </tr> <tr> <td>用户ID</td> <td> <% out.print(userID); %> </td> </tr> <tr> <td>访问次数</td> <td> <% out.print(visitCount); %> </td> </tr> </table> </div> </body> </html>
编写完成上面代码后,部署项目然后运行,打开浏览器尝试访问:http://localhost:8080/SessionTracking/
。将看到以下结果 -
现在尝试再次运行(刷新)相同的JSP页面,可以看到访问次数更新为2
,如下图所示 -
删除会话数据
完成用户的会话数据后,有几个方式用来删除会话信息 -
- 删除一个指定的属性 - 可以调用
public void removeAttribute(String name)
方法来删除与特定键相关联的值。 - 删除整个会话信息 - 可以调用
public void invalidate()
方法来删除(丢弃)整个会话信息。 - 设置会话超时 - 可以调用
public void setMaxInactiveInterval(int interval)
方法来单独设置会话的超时。 - 注销登录用户 - 支持servlets 2.4的服务器,可以调用注销将客户端记录在Web服务器之外,并使属于用户的所有会话失效。
- web.xml配置 - 如果使用的是Tomcat,除了上述方法外,还可以在
web.xml
文件中配置会话超时,如下所示-<session-config> <session-timeout>15</session-timeout> </session-config>
<session-timeout>
指定超时表示的时间单位为分钟,上面配置示例将覆盖Tomcat中30
分钟的默认超时。
servlet中的getMaxInactiveInterval()
方法以秒为单位返回该会话的超时时间。 因此,如果会话在web.xml
中配置了15
分钟,那么getMaxInactiveInterval()
方法将返回900
秒。
上一篇:JSP Cookies处理
下一篇:JSP上传文件
- Java教程
- Vim教程
- Swing教程
- Spring教程
- Spring Web Services教程
- Spring MVC教程
- Spring JDBC教程
- Spring Cloud教程
- Spring Boot教程
- Spring Boot CLI教程
- Spring Batch教程
- Spring AOP教程
- PDFBox教程
- JSP教程
- JSF教程
- JPA教程
- Java面向对象设计
- Java设计模式
- Java虚拟机教程
- Java泛型教程
- Java正则表达式教程
- Java数据类型教程
- Java并发编程教程
- Java密码学教程
- Java多线程教程
- Java国际化(i18n)教程
- JavaFX教程
- Java9教程
扫描二维码
程序员编程王