<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        化惡魔為天使,巧移ViewState至SqlServer

        來源:懂視網 責編:小采 時間:2020-11-09 07:24:41
        文檔

        化惡魔為天使,巧移ViewState至SqlServer

        化惡魔為天使,巧移ViewState至SqlServer:(發文后記:還是說清楚前提吧,本文只適用于當不得已才使用ViewState的情況) ViewState 一直以來備受爭議,主要是因為他臃腫的體積,導致客戶的的回傳( PostBack )數據量很大,而其中真正有用的數據又很少,網絡帶寬被浪費不說,用戶的體驗也很差。 最近
        推薦度:
        導讀化惡魔為天使,巧移ViewState至SqlServer:(發文后記:還是說清楚前提吧,本文只適用于當不得已才使用ViewState的情況) ViewState 一直以來備受爭議,主要是因為他臃腫的體積,導致客戶的的回傳( PostBack )數據量很大,而其中真正有用的數據又很少,網絡帶寬被浪費不說,用戶的體驗也很差。 最近

        (發文后記:還是說清楚前提吧,本文只適用于當不得已才使用ViewState的情況) ViewState 一直以來備受爭議,主要是因為他臃腫的體積,導致客戶的的回傳( PostBack )數據量很大,而其中真正有用的數據又很少,網絡帶寬被浪費不說,用戶的體驗也很差。 最近

        (發文后記:還是說清楚前提吧,本文只適用于當不得已才使用ViewState的情況)
        ViewState
        一直以來備受爭議,主要是因為他臃腫的體積,導致客戶的的回傳(PostBack)數據量很大,而其中真正有用的數據又很少,網絡帶寬被浪費不說,用戶的體驗也很差。

        最近項目中用到了TelerikRadGrid,使用服務器端綁定數據后頁面ViewState體積過大,而導致性能嚴重降低,便開始找尋優化方式,盡量將ViewState存在服務器端。

        由于項目已開發至中期,不可能做類似于取消ViewState或使用客戶端綁定之類的大規模改動。

        要想改動量最小化,肯定不能影響原有ViewState的使用,那只能重寫Page類的LoadPageStateFromPersistenceMedium()SavePageStateToPersistenceMedium(object state)的方法,在這兩個Override的方法中把數據存在別的什么地方。

        這時候就來問題了,ViewState只是一個頁面的周期,每打開一個頁面都會生成一個新的ViewState,連刷新都不例外,如果存在文件或數據庫中,這些數據累積起來可不是開玩笑的,而且也用不上了,那還不得要寫過期刪除的方法么?太麻煩了。這時候,Session就發揮大作用了,Session的生命周期長于ViewState,過期會自動刪除,而且還是存在服務器端的,不會增加數據傳輸量,看來很合適。

        代碼如下:

        Code
        public class AmoPage: System.Web.UI.Page
        {
        #region === Move View State To Session ===

        private string _pageGuid = null;
        public string PageGUID
        {
        get
        {
        if (_pageGuid == null)
        _pageGuid = this.Request.Form["__AmoViewState"];
        if (_pageGuid == null)
        _pageGuid = Guid.NewGuid().ToString();
        return _pageGuid;
        }
        set { _pageGuid = value; }
        }

        protected override object LoadPageStateFromPersistenceMedium()
        {
        return Session[this.PageGUID];
        }

        protected override void SavePageStateToPersistenceMedium(object state)
        {
        RegisterHiddenField("__AmoViewState", this.PageGUID);
        Session[this.PageGUID] = state;
        }

        #endregion
        }


        但是不能忽略一個問題,Session默認是由WebServer 管理的,一般只用于存儲會話中用戶登錄信息這種數據量極小的情況,如果直接把ViewState這個大胖子塞進去,全部是保存在內存中的,無疑用不了多長時間,WebServer就會因為Session數據量過大而崩潰。看來我們還需要轉移Session

        正好,ASP.NET支持自定義會話管理的方式:

        開始-> All Programs-> Microsoft Visual Studio 2008->Visual Studio Tools->Visual Studio 2008 Command Prompt

        進入VS命令行模式。

        執行 aspnet_regsql –S (192.168.19.250) –U sa –P 123 –ssadd

        這是指使用用戶名sa 密碼123登錄到SQLServer服務器192.168.19.250上添加狀態管理相關的數據庫。其實它是建立了一個只有出口存儲過程的數據庫ASPState,并在系統數據庫tempdb中加入了兩張分別用于存儲Application Session的表。

        這時候我們就完成了狀態管理相關的數據庫的創建,然后只要在 Web.config中做如下設置即可





        這時候,該Web應用的Session數據就會存儲于數據庫中。

        在使用的時候,只要將原有的頁面都從AmoPage類繼承就行。

        至于效果,試過就知道!
        使用前:(很熟悉吧...)

        使用后:(干凈,清透,沒問題!)

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        化惡魔為天使,巧移ViewState至SqlServer

        化惡魔為天使,巧移ViewState至SqlServer:(發文后記:還是說清楚前提吧,本文只適用于當不得已才使用ViewState的情況) ViewState 一直以來備受爭議,主要是因為他臃腫的體積,導致客戶的的回傳( PostBack )數據量很大,而其中真正有用的數據又很少,網絡帶寬被浪費不說,用戶的體驗也很差。 最近
        推薦度:
        標簽: sql 惡魔
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 最新猫咪www免费人成| 精品免费人成视频app| www国产亚洲精品久久久日本| 一级特黄a免费大片| 18禁无遮挡无码国产免费网站| 亚洲爆乳无码一区二区三区| 亚洲无码在线播放| 精品一区二区三区免费观看| 亚洲性在线看高清h片| 一个人免费观看视频在线中文| 亚洲女同成人AⅤ人片在线观看| 91av免费在线视频| 国产亚洲精品自在久久| 亚洲av中文无码乱人伦在线观看| 成人免费av一区二区三区| 亚洲精品无码久久千人斩| 99在线视频免费| 亚洲人成毛片线播放| 中国在线观看免费国语版| 激情无码亚洲一区二区三区| 午夜亚洲国产成人不卡在线| 99在线视频免费观看| 免费a级毛片在线观看| www免费黄色网| 亚洲精品视频在线| 免费视频淫片aa毛片| 色妞www精品视频免费看| 国产亚洲人成A在线V网站| 黄网站色成年片大免费高清| 亚洲一区视频在线播放| 久久午夜羞羞影院免费观看| 亚洲精品无码不卡在线播放| 亚洲乱码日产精品a级毛片久久| 国产激情免费视频在线观看| 亚洲精品无码不卡在线播放HE | 亚洲va无码va在线va天堂| 美女视频黄是免费的网址| 亚洲日本一区二区三区| 18禁无遮挡无码网站免费| 一级女人18片毛片免费视频| 久久亚洲国产成人精品性色|