Cookie对象是用来存储有关当前用户数据的小信息包,它可以在浏览器和Web服务器之间传递。在Web应用中,Cookie提供了一种用于跟踪、记录每个用户位置的机制。Cookie最常见的用处之一,就是保存一个Web应用中最后一次被访问的网络页面的时间以及日期或被访问的网址。
通常,Cookie对象在客户端Windows系统目录下Cookies子目录中以文件形式存储。存储在Cookie对象中的信息数据能够被保存较长时间,所以,可以将会话级变量备份在Cookie对象中,在Session对象失效后,通过检索并利用Cookie对象中的信息来自动恢复断点。
Cookie对象具有如下几个属性:
●Expires:设定Cookie对象到期的日期;
●Domain:将Cookie对象的传送确定为仅由Domain属性确定的成员;
●Path:确定Cookie对象传送路径;
●Secure:明确Cookie对象是否安全;
●HasKeys:返回Cookie对象是否包含多值。
如果没有显式定义Cookie对象的Expires属性,Cookie对象将在用户会话期结束时到期。
具体实现
下面通过一个基于ASP.net C#技术来实现,介绍如何处理Session对象变量失效的问题。
●在用户登录时,设置会话级变量并备份到客户端Cookie对象中。
... ... //登录代码省略,将登录名称存储在Session["User"]中;
//创建一个HttpCookie对象
HttpCookie Cookie= new HttpCookie("User");
//用Cookie备份User
Cookie.Value = Session["User"].ToString();
//设定Cookies的生命周期,在这里定义为一个小时
DateTime dtNow = DateTime.Now;
TimeSpan tsMinute = new TimeSpan(0, 1, 0, 0);
Cookie.Expires = dtNow + tsMinute;
//加入此Cookie
Response.Cookies.Add(Cookie);
●在处理业务功能的时候,读取Session["User"],如果该对象已经失效,则通过读取Cookie对象,恢复该Session["User"]对象的属性值。
if (Session["User"] == null)
{
//如果变量已经失效,则检索客户端Cookie对象
HttpCookie Cookie= System.Web.HttpContext.Current.Request.Cookies["User"];
if (Cookie!= null)
{
if (Cookie.Value != "") Session["User"] = Cookie.Value;
}
}
//如果用户未经过登录就进入该业务功能,则该Cookie对象属性值为空。此时,可提示用户出错,并转向用户登录页面
if (Session["User"] == null)
{
... ...//提示出错
Page.Response.Redirect("/USer/Login.aspx");
}
●当用户退出程序时,清除会话级对象和Cookie对象。
Session["User"] = null;
HttpCookie Cookie;
Cookie= new HttpCookie("User");
Cookie.Expires = DateTime.Now.AddDays(-1);//让Cookie过期由浏览器自动消除
Response.Cookies.Add(Cookie);
Response.Redirect("/Default.aspx");
以上代码在.net 3.5环境C#中运行通过。
小 结
Session对象与Cookie对象在客户端联合存取会话级变量的方法简单实用,并且能够有效地避免用户强行登录等问题,不失为一种较好地解决Session对象失效的客户端方法。
Asp版本的代码取经网也有收录,请您搜索Session可找到。