真正理解ViewState

如果不注意ViewState会对应用带来很多不利的影响:
- 泄漏重要的数据
- ViewState攻击
- 性能受影响
- 应用程序不能扩展:如果用户会在每一次Postback的时候都加少50K的ViewState数据。。。
- 影响整体设计

ViewState干些啥:
- 存值
- 跟踪变化

1. 保存键-值对,和Hash表一样用。
ViewState是定义在System.Web.UI.Control上的一个protected property。服务器控件使用ViewState来保存大部分的属性。
一个普通的Property可以如下实现,

但对于ASP.net控件的属性,它们则使用ViewState的StateBag

Default Value
控件通常采用如下的方法来设定初始值

2. 跟踪变化:
可以通过调用System.Web.UI.Control.TrackViewState()来跟踪ViewState的变化。
StateBag类提供了一些可以用来判读ViewState状态的方法
IsItemDirty(string key); SetItemDirty(string key, bool value);
注意:
只有在TrackViewState开启之后的赋值才会被跟踪。
每一次赋值会被跟踪,即使赋和原来一样的值。

?为什么要Track?而不是直接取ViewState值来比较?

3 序列化和反序列化
ViewState被存在一个名叫“_VIEWSTATE”的HiddenField中(地球人都知道)。base64编码的字符串。
ASP.net的页面的空间层次结构(the hierarchy of controls)System.Web.UI.Control.SaveViewState。其实就是Call每个Control的ViewState的SaveViewState方法。对控件树中每个控件递归的调用这个方法就可以生成另一颗数据树。当这个方法返回的时候,ViewState就被序列化了。但是只有那些脏的ViewState才会被序列化。这就是为什么要有TrackViewState的原因。ASP.net页面在OnInit中调用TrackViewState,也就是在控件赋初始值之后。所以在页面中为控件赋值,无论赋什么值,ViewState的长度都不会变。

4 自动恢复(Restores Data)数据
LoadViewState返回一个object对象。这个LoadViewState也是调用StateBag类的方法。最终都是搞这个StateBag类。StateBag就用新的数据来重建键-值表。通过LoadViewState赋值的新的数据类型为System.Web.UI.Pair。Pair有两个值:First和Second。First是一个包含Keys的ArrayList,Second是包含Values的ArrayList。只有被表示为Dirty的那些数据才会通过LoadViewState被传入。

让我们再回过头来看看整个页面的载入过程:
页面Load时,首先将属性值赋为初始值。
而后,在OnInit中,.net调用所有StateBags的TrackViewState方法
接下来,LoadViewState()重载前一次调用的所有脏数据。StateBag.Add(key, Value)。因为此时已经开始TrackViewState(),所以这里载入的数据都被标记为脏,并将在下一次PostBack中被载入。ViewState就是这么回事儿。
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
ASP.NET ViewState 是一种用于在 Web 应用程序中跨请求存储数据的机制。以下是一个使用 ViewState 的示例: 假设您有一个页面,其中包含一个文本框和一个按钮。用户在文本框中输入一些文本,然后单击按钮。在单击按钮时,将在服务器端处理程序中使用 ViewState 存储文本框中的,并在页面上显示它。 以下是一个简单的 ASP.NET 页面代码示例,它演示了如何使用 ViewState 存储和检索文本框中的: ```html <%@ Page Language="C#" %> <!DOCTYPE html> <html> <head runat="server"> <title>ViewState Example</title> </head> <body> <form id="form1" runat="server"> <div> <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox> <br /> <asp:Button ID="Button1" runat="server" Text="Save" OnClick="Button1_Click" /> <br /> <asp:Label ID="Label1" runat="server"></asp:Label> </div> </form> </body> </html> ``` 在按钮单击事件处理程序中,我们将文本框中的存储在 ViewState 中,并将其显示在页面上: ```csharp protected void Button1_Click(object sender, EventArgs e) { string text = TextBox1.Text; ViewState["myText"] = text; Label1.Text = "Text saved: " + text; } ``` 在页面加载事件处理程序中,我们检索存储在 ViewState 中的,并将其显示在页面上: ```csharp protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { if (ViewState["myText"] != null) { string text = (string)ViewState["myText"]; Label1.Text = "Text retrieved: " + text; } } } ``` 通过这种方式,我们可以在页面上保留用户在文本框中输入的,即使用户单击其他按钮或导航到其他页面。请注意,ViewState 可能会增加页面大小,并增加网络传输时间。因此,我们应该谨慎使用 ViewState,并仅在必要时使用它。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值