在 ASP.NET 中,ViewState 因為在客戶端的 HTML 裡占據大量的空間,並隨 著頁面的 PostBack 反復傳遞於網絡中,一直為人垢病。但是實際上 ViewState 可以存儲到數據庫、緩存等任意地方,從而避免頻繁將冗長的 base64 字符串發 送到客戶端。這樣做不但可以顯著提高性能(大幅度減少了網絡傳輸的字節數) ,而且如果其中的內容也不會被輕易解密和破解。因此這個方法是很有用處的。
以下寫了一個簡單的例子,用緩存來作為 ViewState 存儲目的地。至於 緩存的 Key,文中給出的只是一個簡單的寫法,具體可以根據情況給出嚴密的方 案。
代碼大致演示如下:
<%@ Page language="c#" Codebehind="SaveViewStateToOther.aspx.cs" AutoEventWireup="false" Inherits="LinkedList.SaveViewStateToOther" %>
<! DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<html>
<head>
<title>SaveViewStateToOther</title>
<meta name="GENERATOR" Content="Microsoft Visual Studio .NET 7.1">
<meta name="CODE_LANGUAGE" Content="C#">
<meta name=vs_defaultClientScript content="JavaScript">
<meta name=vs_targetSchema content="http://schemas.microsoft.com/intellisense/ie5">< br /> </head>
<body MS_POSITIONING="GridLayout">
<form id="Form1" method="post" runat="server"><asp:DataGrid id=DataGrid1 style="Z-INDEX: 101; LEFT: 104px; POSITION: absolute; TOP: 72px" runat="server" BorderColor="#3366CC" BorderStyle="None" BorderWidth="1px" BackColor="White" CellPadding="4" PageSize="6" AllowPaging="True">
<selecteditemstyle font-bold="True" forecolor="#CCFF99" backcolor="#009999">
</SelectedItemStyle>
<itemstyle forecolor="#003399" backcolor="White">
</ItemStyle>
<headerstyle font- bold="True" forecolor="#CCCCFF" backcolor="#003399">
</HeaderStyle>
<footerstyle forecolor="#003399" backcolor="#99CCCC">
</FooterStyle>
<pagerstyle horizontalalign="Left" forecolor="#003399" backcolor="#99CCCC" pagebuttoncount="20" mode="NumericPages">
</PagerStyle>
</asp:DataGrid>
</form>
</body>
</html>
using System;
using System.Data;
using System.IO;
using System.Text;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace LinkedList
{
/// <summary>
/// SaveViewStateToOther 的摘要說明 。
/// </summary>
public class SaveViewStateToOther : Page
{
protected DataGrid DataGrid1;
private void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
Bind();
}
private void Bind()
{
DataTable table = new DataTable();
table.Columns.Add("id", typeof (int));
table.Columns.Add("name", typeof (string));
for (int i = 0; i < 1000; i++)
{
DataRow row = table.NewRow();
row["id"] = i;
row ["name"] = "student_" + i.ToString();
table.Rows.Add(row);
}
DataGrid1.DataSource = table;
DataGrid1.DataBind ();
}