作者:王奎 欢迎访问我的网站:www.marksaas.com
首先来说一下Jsp中的隐式对象吧,Jsp中有9大隐式对象,分别为request,response,out,session,application,pageContext,config,page,exception,今天主要来说一下session中的生命周期管理问题,在看本文中之前可以看一下我以前写的文章 :jsp和servlet之间的关系+示例入门
什么是session呢,session可以简单的理解为一次会话过程,当你用浏览器向服务器发送信息时一次会话就开始了,当你关闭浏览器和服务器是会话就结束了。当然也可以人为的关闭session,例如,60秒后让session自动失效,下面我们来看一段代码:
sessionTest.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>session life cycle</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
<%
if(session.isNew()){
session.setMaxInactiveInterval(60);//60秒内没有活动,则session过期
session.setAttribute("expire","60");
out.println("设定session60秒内没有活动,则session过期");
}else{
String expiretime=(String)session.getAttribute("expire");
long createTime=session.getCreationTime();//取得session的创建时间
long accessTime=session.getLastAccessedTime();//取得session最后访问时间
long currentTime=System.currentTimeMillis();//取得系统当前时间
long existTime=(currentTime-createTime);//计算session存在时间
out.println("session已经存在"+existTime+"秒");
if(existTime>60){
out.println("session 事件已到期,自动失效");
session.invalidate();//使session失效
}
}
%>
</body>
</html>
我们把项目部署到服务器后链接到sessionTest.jsp后,过60秒后刷新就好显示session已失效。。
自己部署到服务器上试一下吧。。