前几天写了篇
将视图状态存入数据库(3),这次发布的文件,修正了当控件状态比较小时,不保存在数据库中,而是保存在页面上。
using System;
using System.Web.UI;
using System.IO;
using ICSharpCode.SharpZipLib.Zip.Compression;
using System.Collections;
using JianCaiWeb.DbAccess;
using System.Text;
using System.Collections.Generic;
using System.Reflection;
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
namespace JianCaiWeb.Utils
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 读取控件状态,不是直接从数据库读取,而是先去状态池中查找,如果状态池中不存在,我们再访问数据库。
///
/// 状态池中的元素都是未序列化的,这样就避免了序列化和反序列化带来的性能问题。
/// </summary>
public class DatabasePageStatePersister : PageStatePersister
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
private static DataAccess da;
private static int limitLength = 548;
//状态池
private static List<DictionaryEntry> list = new List<DictionaryEntry>();
//状态池大小
private static int viewStateCount = 1000;
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public DatabasePageStatePersister(Page page)
: base(page)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
da = DataAccessFactory.CreateDataAccess();
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
//在 Page 对象初始化其控件层次结构时,加载保留的状态信息
public override void Load()
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
Pair statePair = null;
string clicentState = this.Page.Request["__VIEWSTATE"].ToString();
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
if (clicentState.Length != 0)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
//获取页面的StateFormmatter
IStateFormatter formatter = this.StateFormatter;
//序列化控件状态
statePair = (Pair)formatter.Deserialize(clicentState);
}
else
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
string stateID = base.Page.Request["__VIEWSTATE_KEY"].ToString();
statePair = this.LoadViewState(stateID);
}
this.ViewState = statePair.First;
this.ControlState = statePair.Second;
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
// 在从内存中卸载 Page 对象时,对所保留的状态信息进行序列化。
public override void Save()
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (this.ViewState != null || this.ControlState != null)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
Guid guid = Guid.NewGuid();
string viewStateID = guid.ToString();
base.Page.ClientScript.RegisterHiddenField("__VIEWSTATE_KEY", viewStateID);
Pair statePair = new Pair(ViewState, ControlState);
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
//获取页面的StateFormmatter
IStateFormatter formatter = this.StateFormatter;
//序列化控件状态
string serializedState = formatter.Serialize(statePair);
if (serializedState.Length < limitLength)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
//通过反射,找到页面实例的ClientState属性,将控件状态赋值给改属性
Type type = this.Page.GetType();
PropertyInfo property = type.GetProperty("ClientState", BindingFlags.Instance | BindingFlags.NonPublic);
property.SetValue(this.Page, serializedState, null);
}
else
this.SaveViewState(viewStateID, statePair, serializedState);
}
}
//保存视图状态至状态池或数据库
private void SaveViewState(string viewStateID, Pair statePair, string serializedState)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
DictionaryEntry newEntry = new DictionaryEntry();
newEntry.Key = viewStateID;
newEntry.Value = statePair;
list.Add(newEntry);
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
string strSql = string.Format("insert into ViewState (viewStateID,ViewState) values ('{0}','{1}');", viewStateID, serializedState);
//将控件状态存入数据库
da.ExecuteNonQuery(strSql);
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
//当状态池中的元素数量大于等于1000时,从开始位置移除多余的元素
if (list.Count >= viewStateCount)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
list.RemoveRange(0, list.Count - viewStateCount);
}
}
//从状态池或数据库中读取控件状态
private Pair LoadViewState(string viewStateID)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
Pair statePair = null;
//遍历状态池,找到相应的控件状态
foreach (DictionaryEntry entry in list)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (entry.Key.ToString() == viewStateID)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
statePair = (Pair)entry.Value;
break;
}
}
//如果状态池中没有找到相应的控件状态,则从数据库中读取
if (statePair == null)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
string strSql = "select viewState from viewState where viewStateID = '" + viewStateID + "'";
string viewState = da.ExecuteScalar(strSql).ToString();
//获取页面的StateFormmatter
IStateFormatter formatter = this.StateFormatter;
//序列化控件状态
statePair = (Pair)formatter.Deserialize(viewState);
}
return statePair;
}
}
}
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
具体怎么使用,参考
将视图状态存入数据库(3)。