概述ASP.NET状态类型


  本文标签:ASP.NET状态类型

  提供了四种ASP.NET状态类型:application,session,cookie,view  。

  Application状态为应用程序提供了一个全局的状态  。所有客户都可以使用该状态  。从设计的角度来说,我们通常用Application来存储一些标准的数据  。同时,我们在使用它时要注意避免性能的降低,存储的数据尽可能提供给客户只读的功能  。

  我们可以使用HttpApplication类的Application属性来访问Application状态,它返回一个 HttpApplicationState类的实例  。这个类是一个对象集合,可以存储任何类型的数据,并以键/值对的形式存储  。一旦数据被存储到状态后,就不会删除,除非应用程序重新启动或者被终止或回收  。

  我们可以在Global.asax的Application_Start函数中存储数据:

  1. void Application_Start(object src, EventArgs e)  
  2. {  
  3. int exp = 0;  
  4. // population of dataset from ADO.NET query not shown  
  5. // Cache DataSet reference  
  6. Application["Experiment"] = exp;  
  7. }  
  8. 现在你可以在任意页面下使用它:  
  9. private void Page_Load(object src, EventArgs e)  
  10. {  
  11. int expr = Int32.Parse((Application["Experiment"]));  

  于Application状态对于所有客户都是共享的,如果客户只是读取该数据,则没有什么问题,一旦要进行写操作,就不能保证线程的安全以及出现同步争用的问题  。我们可以使用HttpApplicationStateLock类,它派生于ReadWriteObjectLock类,它提供了读/写锁的两种属性  。在ASP.NET下,隐式地调用了AcquireWrite()和AcquireRead()方法以保证避免上面的问题  。当然,我们也可以显示地使用Lock()和Unlock():

  1. private void Page_Load(object sender, System.EventArgs e)  
  2. {  
  3. Application.Lock();  
  4. int expr = Int32.Parse((Application["Experiment"]));  
  5. if (expr>=something)  
  6. {  
  7. //do something  
  8.  }  
  9. Else  
  10. {  
  11. //do something else  
  12.  }  
  13. Application.UnLock();  
  14. //Some other thing goes here  

  
session,cookie,view状态都是用来保存客户端信息的ASP.NET状态类型  。它们之间又有什么区别呢?

  Session状态是在客户登录的时候创建的,它保存了客户特定的信息,并以Session ID来标识  。当一个新客户访问应用程序时,先生成一个新的Session ID(或是Session Key),并为同一个客户接下来的请求创建联系  。你可以在Session State中存储任意类型的数据,作为你的应用,状态被同一个进程和AppDomain(App域)维护  。Session State的特点是为每一个特定的客户创建状态以维护客户的信息,这些状态信息存储在服务器端的默认的会话状态配置中  。

  1. Session(“Value”) = expr ; // Storing the data into session object  
  2. SomeFunction()  
  3. {  
  4. int expr = Int32.Parse(Session(“Value”));//Accessing from it  
  5.  if (expr>=something)  
  6. {  
  7. //do something  
  8.  }  
  9. Else  
  10. {  
  11. //do something else  
  12.  }  
  13. //Some other thing goes here  

  既然Session State针对特定的客户建立,通过它来识别客户的请求  。ASP.NET提供了一种加密机制和编码算法生成自己的Session Key  。这是非常必要的,因为知道了你的Session Key,就有权限访问指定的页面了  。

  在ASP.NET中生成Session Key的方法:

  1. byte[] sessionkey = new byte[15];  
  2. //Generates a random number  
  3. RNGCryptoServiceProvider rngkey = new RNGCryptoServiceProvider ();  
  4. rngkey.GetBytes (sessionkey);  
  5. string clientsessionKey = SessionId.Encode (sessionkey); 

  
但是Session和客户端的Cookie是有关的,当客户关掉Cookie时,Session就失效了  。不过在ASP.NET中可以在web.config中修改设置,使Session的传递脱离Cookie  。方法是:

  1. <configuration> 
  2. <system.web> 
  3. <sessionState cookieless="true" /> 
  4. system.web> 
  5. configuration> 

  对于Cookie大家并不陌生,每个Cookie存储了多个名/值对,我们可以通过HttpCookie类的值集合来访问它,也可以间接地通过类所提供的索引器访问  。Cookie在ASP.NET下的使用:

  1. protected void Page_Load(Object sender, EventArgs E)  
  2. {  
  3. int expr = 0;  
  4. if (Request.Cookies["Expr"] == null)  
  5. {  
  6. // "Expr" cookie not set, set with this response  
  7.   HttpCookie cokExpr = new HttpCookie("Expr");  
  8. cokExpr.Value = exprTextBox.Text;  
  9. Response.Cookies.Add(cokExpr);  
  10. expr = Convert.ToInt32(exprTextBox.Text);  
  11. }  
  12. else  
  13. {  
  14. // use existing cookie value...  
  15.   expr = Convert.ToInt32(Request.Cookies["Expr"].Value);  
  16. }  
  17. // use expr to customize page  

  由于Cookie存储的信息是放到客户端的,用户在访问服务器端页面时,必然在客户端和服务器端之间频繁交换信息,影响了程序的性能  。而Session由于存储在服务器内存中,因此不存在这个问题  。不过,Session存储的信息是临时的,用户一旦关闭浏览器,状态即失去,而Cookie则相反  。以上介绍ASP.NET状态类型