ASP.NET中Cookie和session的使用

转载 2012年03月29日 23:27:32

http://blog.csdn.net/pcfree2008/article/details/4755254

 Session是什么呢?简单来说就是服务器给客户端的一个编号。当一台WWW服务器运行时,可能有若干个用户浏览正在运正在这台服务器上的网站。当每个用户首次与这台WWW服务器建立连接时,他就与这个服务器建立了一个Session,同时服务器会自动为其分配一个SessionID,用以标识这个用户的唯一身份。这个SessionID是由WWW服务器随机产生的一个由24个字符组成的字符串.

     这个唯一的SessionID是有很大的实际意义的。当一个用户提交了表单时,浏览器会将用户的SessionID自动附加在HTTP头信息中,(这是浏览器的自动功能,用户不会察觉到),当服务器处理完这个表单后,将结果返回给SessionID所对应的用户。试想,如果没有SessionID,当有两个用户同时进行注册时,服务器怎样才能知道到底是哪个用户提交了哪个表单呢。当然,SessionID还有很多其他的作用.

     可能有些有些读者会问:这个看似像是数组的Session(“..”)是哪里来的?需要我定义吗?实际上,这个Session对象是具有ASP解释能力的的WWW服务器的内建对象。也就是说ASP的系统中已经给你定义好了这个对象,你只需要使用就行了。其中Session(“..”)中的..就好像变量名称,Session(“..”)=$$$中的$$$就是变量的值了。你只需要写上句话,在这个用户的每个页面中都可以访问..变量中的值了。

     其实ASP一共内建了7个对象,有Session、Application、Cookie、Response、Request、Server等。在其他的服务器端脚本语言如JSP、PHP等中也有其类似的对象,只是叫法或者使用方法上不太一样。

例题:设计意图:将login页面中的登录信息保存在login的Cookie中,转到Home页面时,利用得到的Cookie值就能自动登录 

login页面前台关于Cookie的代码:

<td>
      &nbsp;&nbsp;&nbsp;&nbsp;
        <asp:DropDownList ID="time" runat="server">
           <asp:ListItem Selected="True" Value="1">不保存</asp:ListItem>
           <asp:ListItem Value="14">两周</asp:ListItem>
           <asp:ListItem Value="30">一个月</asp:ListItem>
           <asp:ListItem Value="0">不创建</asp:ListItem>
        </asp:DropDownList>

</td>

 

login页面后台关于Cookie的代码:

protected void Login_Click(object sender, EventArgs e)
    {

        //创建一个新的Cookie
        HttpCookie newCookie = new HttpCookie("User");

 

        //往Cookie里面添加值,均为键/值对。Cookie可以根据关键字寻找到相应的值
        newCookie.Values.Add("Name",nameID.Text.Trim());
        newCookie.Values.Add("Pwd",pwdID.Text.Trim());
        

       //设置Session的值

        Session["Name"] = nameID.Text.Trim();
        Session["Pwd"] = pwdID.Text.Trim();

        if (time.SelectedValue == "14")
        {
            newCookie.Expires = DateTime.Now.AddDays(14);
        }
        else if (time.SelectedValue == "30")
        {
            newCookie.Expires = DateTime.Now.AddDays(30);
        }
        else if (time.SelectedValue == "0")
        {
            newCookie.Expires = DateTime.Now.AddDays(0);
        }

 

        //Cookie的设置页面要用Response
        Response.AppendCookie(newCookie);
        Response.Redirect("Home.aspx");
    }

 

    //Home页面前台代码

   <asp:Button ID="btnReset" runat="server" Text="注销" onclick="btnReset_Click" 
            Visible="False" />

 

//Home页面后台代码

protected void Page_Load(object sender, EventArgs e)
    {

        //获得login页面的Cookie值 要用Request
        HttpCookie newCookie = Request.Cookies["User"];
        if (newCookie != null)
        {
            Response.Write("欢迎" + newCookie.Values["Name"] + "来到该网站," + "你的密码是:" + newCookie.Values["Pwd"]);
            btnReset.Visible = true;
        }

 

        //获得login页面的session值
         if (Session["Name"] != null)
        {
            Response.Write("欢迎" + Session["Name"] + "来到该网站," + "你的密码是:" + Session["Pwd"]);
            btnReset.Visible = true;
        }
        else
        {
            Response.Write("您还没有登陆!<a href='Login.aspx'>返回登陆</a>");
        }
    }
    protected void btnReset_Click(object sender, EventArgs e)
    {
        HttpCookie newCookie = Request.Cookies["User"];
        if (newCookie != null)
        {
            newCookie.Expires = DateTime.Now.AddDays(-1);

            Response.Cookies.Add(newCookie);
            Response.Redirect("Login.aspx");
        }
    }


ASP.NET之Application、Session和Cookie的区别

在Asp.net中Application、Session和Cookie都可以保存信息,那么它们有什么不同呢?    一、首先Application是在服务器端建立一个状态变量,存储于服务器的全局变量来...
  • u010858791
  • u010858791
  • 2014年10月23日 17:16
  • 2272

ASP.NET 之深入浅出Session和Cookie

Cookie的使用最主要的注意事项时其生命周期和其安全性,如何防止Cookie的欺骗是后续深入研究学习的,安全性上讲,伪造session要比cookie难得多,session相对更安全一些.为了数据的...
  • lishehe
  • lishehe
  • 2013年08月04日 18:03
  • 3756

ASP.Net一般处理程序Session用法,以及cookie的用法

转载地址:http://blog.sina.com.cn/s/blog_7bbc54570100sg5h.html 1.在aspx和aspx.cs中,都是以Session["xxx"]="aaa"和...
  • xxt1993
  • xxt1993
  • 2015年09月17日 09:47
  • 2872

Asp.Net Cookie 和 Session 的编写、读取 和 删除

一、Cookie(分两种操作方式) (一)第一种操作方式 #region 第一种操作方式 //(一)未带子健的 Cookie //1.编写(创建 和 修改 一样) HttpCookie cookie...
  • lichunlin1994
  • lichunlin1994
  • 2016年12月12日 00:01
  • 1416

java 中session和cookie的使用

这里讲session和cookie放在一起写, 不是说他们之间有什么关系,仅最近一个项目中同时用到。偷懒,放一起整理下 Session: Session的发明是为了填补HTTP协议的局限。请注意H...
  • kongjing0815
  • kongjing0815
  • 2012年03月09日 10:49
  • 9014

Asp.Net使用加密cookie代替session验证用户登录状态 源码分享 欢迎拍砖

小论坛地址:http://rayyu.5d6d.com/thread-9444-1-1.html 正文: 首先 session 和 cache 拥有各自的优势而存在.  他们的优劣...
  • rayyu1989
  • rayyu1989
  • 2012年04月29日 14:52
  • 7258

PHP Cookie与Session的使用与区别

Cookie与Session Cookie和session是目前使用的两种存储机制。 cookie是从一个WEB页到下一个WEB页面的数据传送方法,cookie存储在客户端。 Session是让...
  • czh0423
  • czh0423
  • 2015年06月02日 16:09
  • 2891

AspNet MVC4 教学-16:Asp.Net MVC4 Session及Cookie快速比较Demo

Asp.Net MVC4 Session及Cookie快速比较Demo
  • vinglemar
  • vinglemar
  • 2015年05月20日 07:06
  • 5898

cookie和session工作机制和使用场合详解

虽然session机制在web应用程序中被采用已经很长时间了,但是仍然有很多人不清楚session机制的本质,以至不能正确的应用这一技术。本文将详细讨论session的工作机制并且对在Java web...
  • jaryle
  • jaryle
  • 2016年08月21日 18:40
  • 1081

jsp中cookie与session等自己总结精华

(1)  JSP中的九大内置对象 page  request session   application   pagecontext   response  config  out         ...
  • sky_sea_desert_me
  • sky_sea_desert_me
  • 2016年11月12日 19:22
  • 725
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP.NET中Cookie和session的使用
举报原因:
原因补充:

(最多只允许输入30个字)