• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Asp.Net中狀態管理了解

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

一、頁面保存狀態
方式

    Http協議是無狀態的,從客戶端到服務器的連接可以在每個請求之后關閉。但是一般需要把一些客戶端信息從一個頁面傳送給另一個頁面,這時需要保存狀態。頁面保存狀態方式如下:

狀態類型

客戶端或服務器資源

有效時間

ViewState

客戶端

只在一個頁面中

Cookie

客戶端

關閉瀏覽器時會刪除臨時cookie或永久cookie存儲在客戶端系統的磁盤上

Session

服務器

會話狀態與瀏覽器會話相關。會話在超時后無效(默認為20分鐘)

Application

服務器

應用程序狀態在所有的客戶端上共享,這個狀態在服務器重啟動之前都有效的

Cache

服務器

類似於應用程序狀態,高速緩存是共享的。但是,使高速緩存無效有更好的控制方式。


二、客戶端狀態與服務器端狀態的缺點:
   使用客戶端的狀態,其缺點在於增加了數據在網絡之間的傳送。使用服務器狀態的缺點在於,服務器必須組客戶端分配資源。


三、客戶端狀態管理
    3.1
ViewState
        Web
服務器控件自動使用ViewState來使事件工作。ViewState包含的狀態與控件發送給客戶端時包含的狀態相同。當瀏覽器把窗體發送回服務器,ViewState包含了初始值,但所發送的控件包含新值。如果初始值和新值區別,就調用相應的事件處理程序。
      ViewState
只保存在面面中,如果狀態應保存在多個不同頁面中,就應使用cookie在客戶端保存狀態。
      ViewState
缺點是:數據總是要從服務器傳送給客戶端,再從客戶端傳送給服務器,增加了網絡流量。
         為了減少流量,可以關閉
ViewState。在Page指令中把EnableViewState屬性設置為false,這樣可以關閉頁面中所有控件的ViewState。如下代碼:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs"
Inherits
="_Default" EnableViewState="false" %>

 

         我們也可以單獨設置控件的EnableViewState屬性,這樣無論頁面進行了什麼配置,都可以使用控件配置的值。

        我們也可以將定製的數據存儲在ViewState中。代碼如下: 

ViewState["SaveValue"= "Need Save Value";

    在發送給客戶的HTML代碼中,整個頁面的ViewState存儲在一個隱藏的字段中。如下面代碼:

<input type="hidden" name="__VIEWSTATE" id="__VIEWSTATE"
value
="/wEPDwULLTE5MTkwMTIzNDNkZKJI5cFHnBD9NmyabrvirIrUDjIH" />

      使用隱藏字段的優點是,每個瀏覽器都可以使用這個特性,用戶不關閉它。

3.2cookie
    Cookiehttp頭中定義,使用httpResponse類可以把cookie發磅給客戶端。ResponsePage類的一個屬性,它返回一個HttpResponse類型的對象。HttpResponse類定義了返回HttpCookieCollectionCookies屬性。使用HttoCookieCollection可以給客戶端返加多個cookie。(如查要發送多個cookie值,最好把值添加到一個cookie中,而不是使用多個cookie

    Cookie可以是臨時的,僅在一個瀏覽器會話中有效,也可以存儲在客戶端的磁盤上。我們可以使用Expires屬性設置cookie有效日期。注:瀏覽器只能為每個服務器存儲20cookie,為所有服務器存儲300cookie。達到這個極限后,就刪除有一段時間未用的cookieCookie不能存儲多於4 K的數據。
如代碼:


        //實例化HttpCookie
        HttpCookie cookie 
= new HttpCookie("cookieName");

        
//增加cookie中的值
        cookie.Values.Add("CookieValueName""CookieValue");

        
//Expires:获取或设置作为 DateTime 的 Cookie 过期日期和时间。
        cookie.Expires 
= DateTime.Now.AddDays(1);

        
/*
         Response:获取与该 Page 对象关联的 HttpResponse 对象。该对象使您得以将 HTTP 响应数据发送到客户端,并包含有关该响应的信息。
        
*/

        Response.Cookies.Add(cookie);

    客戶端從服務器上請求一個頁面時,這個服務器的cookie就可以在客戶端上使用,並作為HTTP請求的一部分發送給服務器。要在Asp.Net頁面中讀取cookie,可以訪問HttpRequest對象中的cookie集合。

    與Http響應一樣, Page業也有一個Request屬性返回HttpRequest類型的對像。Cookies屬性返回HttpCookieCollection,它可以用於於讀取客戶端發送的cookie。可以用索引符通過其名稱來訪問cookies,然后使用HttpCookie的Values屬性從cookie中獲取值。

        //得到Cookie中的值
        HttpCookie hcCoo 
= Request.Cookies["cookieName"];
        
string sCookieValue = cookie.Values["CookieValueName"];


四、服務器端狀態管理

4.1會話(session)
    會話狀態與瀏覽器會話相關。客戶羰在服務器上第一個打開Asp.Net頁面時,會話就開始了。當客戶在20分鐘之內沒有訪問服務器時,會話結束。

    會話狀態可以存儲在HttpSessionState對像中。與當前Http環境相關的會話狀態對像可以使用Page類的Session屬性來訪問。在 Session_Start()事件處理程序中,可以初始化會話變量。

     我們需要對Session運行前後作一些處理時,或以使用Global Application類。用Website->Add New ite->Global Application Class創建Globla Application類。此文件默認名為global.asax。

     會話狀態存儲在HttpSessionState對像中。與當前相關的會話狀態對像可以使用Page類的Session屬性來訪問。

    要把客戶羰與其會話變更關聯起來,Asp.net默認使用一個監時cookie和一個會話標識符。Asp.net 2.0也支持沒有cookie的會話,其中的Url標識符用於把http請求映射到同一個會話。

4.2應用程序狀態(Application)

    如果數據應在多個客戶端共享,就可以使用應用程序狀態。應用程序狀態的使用方式與會話狀態非常類似。應用程序狀態使用HttpApplicationState類,通過Page類的Appliction屬性可以訪問它。

    不要在應用程序狀態中存儲大多的數據。因為應用程序狀態需要服務器資源,直到服務器停止或重啟之后才釋放資源。

4.3高速緩存(Cache)

    高速緩存是服務器端狀態,它類似於應用程序狀態,因為它在所有客戶端上共享。高速緩存與應用程序狀態的區別是,高速緩存要靈活得多:有許多定義狀態何時失效方式。

     高速緩存,需要使用System.Web.Caching命名空間。給高速緩存添加對像的過程如下:Page類的Cache屬性返回一個Cache對像。使用Cache類的Add()方法增加把任意對像。



其它:
Application, Session, Cookie, Viewstate, Cache对象用法和区别

轉自:http://www.cnblogs.com/sojay/archive/2008/03/26/1122489.html



1.Application: 用于保存所有用户共用的数据信息。 在Asp.Net中类似的配置数据最好保存在Web.config文件中。如果使用Application对象,一个需要考虑的问题是任何写操作都要在 Application_OnStart事件(global.asax)中完成。尽管使用Application.Lock和 Application.Unlock方法来避免写操作的同步,但是它串行化了Application对象的请求,当网站访问量大的时候会产生严重的性能 瓶颈。因此最好不要用此对象保存大的数据集。

使用如下:
//存放信息
Application["UserNameID"]="1000";
//读取信息
String NameID=Application["UserNameID"].ToString();


2.Session:用于保存每个用户的专用信息。Session中的信息保存在Web服务器的内存中,保存的数据量可大可小。当Session超时或被关闭时将自动释放保存的数据信息。对于小量的数据Session对象保存还是一个不错的选择。

使用如下:
//存放信息
Session["UserNameID"]="1000";
//读取信息
String NameID=Session["UserNameID"].ToString();


3.Cookie: 用于保存客户浏览器请求服务器页面的请求信息,其有效期可以人为设置,而且其存储的数据量很受限制,因此不要保存数据集及其他大量数据。而且Cookie以明文方式将数据信息保存在客户端的计算机中,因此最好不要保存敏感的未加密的数据。

使用如下:
//存放信息
Response.Cookie["UserNameID"].Value="1000";
//读取信息
String NameID=Response.Cookie["UserNameID"].Value;


4.ViewState: 常用于保存单个用户的状态信息,可以保存大量的数据但是过多使用会影响应用程序的性能。所有Web服务器控件都使用ViewStat在页面回发期间保存自 己的状态信息。每个控件都有自己的ViewState,不用时最好关闭以节省资源。通过给@Page指令添加"EnableViewState= false"属性可以禁止整个页面的ViewState。

使用如下:
//存取信息
ViewState["UserNameID"]="1000";
//读取信息
string NameID=ViewState["UserNameID"].ToString();


5.Cache:用于在Http请求间保存页面和数据。它允许将频繁访问的大量服务器资源存储在内存中,当用户发出相同的请求时服务器不再次处理而是将Cache中保存的信息返回给用户,节省了服务器处理请求时间。

使用如下
//存放信息
Cache["UserNameID"]="1000";
//存放信息
Cache.Insert("UserNameID","1000");
//读取信息
String UserNameID=Cache["UserNameID"].ToString();


6.隐藏域:Hidden控件属于Html类型的服务器控件,可以实现隐藏域的功能,他和其他的空间没什么区别只是不会在浏览器上显示,始终处于隐藏状态。

使用如下:
//存放信息
Hidden.Value="1000";
//读取信息
String UserNameID=Hidden.Value;


7.查询字符串:将传递的值连接在URL后面,然后通过Response.Redirect方法实现客户端的重定向。

使用如下
Response.Redirect("User.aspx?UserNameID=10000&LevelD=100");
执行上面的语句后在IE地址栏显示的URL的代码如下:

         http://localhost/User.aspx?UserNameID=1000&LevelID=100

         当跳转到User.aspx后,可以通过下面代码获得传递的信息:
String UserNameID,LevelD;
UserNameID=Request.Params["UserNameID"];
LevelD=Request["LevelD"];

=================================================================

Application

1.         Application用来保存所有用户共用的信息

2.         在Asp时代,如果要保存的数据在应用程序生存期内不会或者很少发生改变,那么使用Application是理想的选择。但是在Asp.net开发环境中我们把类似的配置数据放在Web.config中。

3.         如 果要使用Application 要注意的是所有的写操作都要在Application_OnStart事件中完成(global.Asax),尽管可以使用 Application.Lock()避免了冲突,但是它串行化了对Application的请求,会产生严重的性能瓶颈。

4.         不要使用Application保存大数据量信息

5.         代码:Application[“UserID”]=”test”;

        String UserName=Application[“UserID”].ToString();

Session

1.         Session用来保存每一个用户的专有信息

2.         Session的生存期是用户持续请求时间加上一段时间(一般是20分钟左右)

3.         Session信息是保存在Web服务器内存中的,保存数据量可大可小

4.         Session超时或者被关闭将自动释放数据信息

5.         由于用户停止使用应用程序之后它仍在内存中存留一段时间,因此这种方法效率较低

6.         代码:Session[“UserID”]=”test”;

        String UserName=Session[“UserID”].ToString();

Cookie

1.         Cookie用来保存客户浏览器请求服务器页面的请求信息

2.         我们可以存放非敏感的用户信息,保存时间可以根据需要设置

3.         如果没有设置Cookie失效日期,它的生命周期保存到关闭浏览器为止

4.         Cookie对象的Expires属性设置为MinValue表示永不过期

5.         Cookie存储的数据量受限制,大多数的浏览器为4K因此不要存放大数据

6.         由于并非所有的浏览器都支持Cookie,数据将以明文的形式保存在客户端

7.         代码:Resopnse.Cookies[“UserID”]=”test”;

        String UserName= Resopnse.Cookies [“UserID”].ToString();

ViewState

1.         ViewState用来保存用户的状态信息,有效期等于页面的生命周期

2.         可以保存大量数据但是要慎用,因为会影响程序性能

3.         所有的Web服务器控件都是用ViewState在页面PostBack期间保存状态

4.         不需要则关闭 @page 里面设置EnableViewState=false

5.         代码:ViewState[”ID”]=”cc”;
   String ID =ViewState[“ID”].ToString();

Cache

1.         Cache用于在Http请求期间保存页面或者数据

2.         Cache的使用可以大大的提高整个应用程序的效率

3.         它允许将频繁访问的服务器资源存储在内存中,当用户发出相同的请求后
服务器不是再次处理而是将Cache中保存的数据直接返回给用户

4.         可以看出Cache节省的是时间—服务器处理时间

5.         Cache实例是每一个应用程序专有的,其生命周期==该应用程序周期
应用程序重启将重新创建其实例

6.         注意:如果要使用缓存的清理、到期管理、依赖项等功能必须使用Insert 或者Add方法方法添加信息

7.         代码:Cache[”ID”]=”cc”;或者Cache.Insert(“ID”,”test”);
   String ID =Cache[“ID”].ToString();

Hidden

1.         Hidden控件属于Html类型的服务器控件,始终处于隐藏状态

2.         每一次提交的时候它会和其他服务器控件一起提交到服务器端

3.         代码如下:Hidden.Value=”cc”;
string id=Hidden.Value; 要使用Runat=server





鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
ASP.NETForms身份认证详解发布时间:2022-07-10
下一篇:
Asp.NetMVC视图(概述)-Part.1发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap