基于ASP.net C#技术来实现,介绍如何处理Session对象变量失效的问题

来源:互联网 发布:淘宝店铺html5 编辑:程序博客网 时间:2024/05/16 15:16

基于ASP.net C#技术来实现,介绍如何处理Session对象变量失效的问题

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可找到。

原创粉丝点击