这个方法内部还可以用压缩算法,进一步缩小viewstate的体积
--------------------------------------------------------------------------------------------------------------------------------------------
如果你有一个非常酷的页面,页面上很多东西自动地响应用户操作而展现丰富的变化,你的ViewState是很有可能达到200K的。
这里是我将ViewState持久化保持在服务器端的代码,这样ViewState不占用网络带宽,因此其存取只是服务器的磁盘读取时间。并且它很小,可以说是磁盘随便转一圈就能同时读取好多ViewState,因此可以说“不占时间”。为了再“不占磁盘时间”,我还使用了缓存。
一下这段代码可以放在页面中,或者页面的父类中:
--------------------------------------------------------------------------------------------------------------------------------------------
如果你有一个非常酷的页面,页面上很多东西自动地响应用户操作而展现丰富的变化,你的ViewState是很有可能达到200K的。
这里是我将ViewState持久化保持在服务器端的代码,这样ViewState不占用网络带宽,因此其存取只是服务器的磁盘读取时间。并且它很小,可以说是磁盘随便转一圈就能同时读取好多ViewState,因此可以说“不占时间”。为了再“不占磁盘时间”,我还使用了缓存。
一下这段代码可以放在页面中,或者页面的父类中:
- protected override object LoadPageStateFromPersistenceMedium()
- {
- var viewStateID = (string)((Pair)base.LoadPageStateFromPersistenceMedium()).Second;
- var stateStr = (string)Cache[viewStateID];
- if (stateStr == null)
- {
- var fn = Path.Combine(this.Request.PhysicalApplicationPath, @"App_Data/ViewState/" + viewStateID);
- stateStr = File.ReadAllText(fn);
- }
- return new ObjectStateFormatter().Deserialize(stateStr);
- }
- protected override void SavePageStateToPersistenceMedium(object state)
- {
- var value = new ObjectStateFormatter().Serialize(state);
- var viewStateID = (DateTime.Now.Ticks + (long)this.GetHashCode()).ToString();
- //产生离散的id号码
- var fn = Path.Combine(this.Request.PhysicalApplicationPath, @"App_Data/ViewState/" + viewStateID);
- ThreadPool.QueueUserWorkItem(obj => File.WriteAllText(fn, value));
- Cache.Insert(viewStateID, value);
- base.SavePageStateToPersistenceMedium(viewStateID);
- }