三、Cookie 这个也是大家常使用的方法,Cookie用于在用户浏览器上存储小块的信息,保存用户的相关信息,比如用户访问某网站时用户的ID,用户的偏好等,用户下次访问就可以通过检索获得以前的信息。所以Cookie也可以在页面间传递值。Cookie通过HTTP头在浏览器和服务器之间来回传递的。Cookie只能包含字符串的值,如果想在Cookie存储整数值,那么需要先转换为字符串的形式。 与Session一样,其是什对每一个用户而言的,但是有个本质的区别,即Cookie是存放在客户端的,而session是存放在服务器端的。而且Cookie的使用要配合ASP.NET内置对象Request来使用。 优点:1.使用简单,是保持用户状态的一种非常常用的方法。比如在购物网站中用户跨多个页面表单时可以用它来保持用户状态。 缺点:1.常常被人认为用来收集用户隐私而遭到批评。 2.安全性不高,容易伪造。 使用方法:1.在源页面的代码中创建你需要传递的名称和值构造Cookie对象: HttpCookie objCookie = new HttpCookie("myCookie","Hello,Cookie!");Response.Cookies.Add(cookie);
2.在目的页面的代码使用Cookie对象取出传递的值:Result = Request.Cookies[ "myCookie" ].Value; 例子:(1)a.aspx private void Button1_Click(object sender, System.EventArgs e){ HttpCookie objCookie = new HttpCookie("myCookie","Hello,Cookie!"); Response.Cookies.Add(objCookie); }
(2)b.aspx string myName1Value;myName1Value = Request.Cookies[ "myCookie" ].Value;
四、Application Application对象的作用范围是整个全局,也就是说对所有用户都有效。它在整个应用程序生命周期中都是有效的,类似于使用全局变量一样,所以可以在不同页面中对它进行存取。它和Session变量的区别在于,前者是所有的用户共用的全局变量,后者是各个用户独有的全局变量。 可能有人会问,既然所有用户都可以使用application变量,那他可以用在什么场合呢?这里举个例子:网站访问数。多个请求访问时都可以对它进行操作。 优点:1.使用简单,消耗较少的服务器资源。 2.不仅能传递简单数据,还能传递对象。 3.数据量大小是不限制的。 缺点:1.作为全局变量容易被误操作。所以单个用户使用的变量一般不能用application。 使用方法:1.在源页面的代码中创建你需要传递的名称和值构造Application变量:Application["Nmae"]="Value(Or Object)"; 2.在目的页面的代码使用Application变量取出传递的值。Result = Application["Nmae"] 注意:常用lock和unlock方法用来锁定和解锁,为了防止并发修改。 例子:(1)a.aspx private void Button1_Click(object sender, System.EventArgs e) { Application["name"] = Label1.Text; }
(2)b.aspx
private void Page_Load(object sender, EventArgs e) { string name; Application.Lock(); name = Application["name"].ToString(); Application.UnLock(); }
|