<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      在ASP.NET中使用Session常見問題集錦(轉)

      在壇子里經常看到一些關于Session的問題,下面做一個總結,希望對大家有所幫助:

      問:為什么Session在有些機器上偶爾會丟失?
      答:可能和機器的環境有關系,比如:防火墻或者殺毒軟件等,嘗試關閉防火墻。

      問:為什么當調用Session.Abandon時并沒有激發Session_End方法?
      答:首先Session_End方法只支持InProc(進程內的)類型的Session。其次要激發Session_End方法,必須存在Session(即系統中已經使用Session了),并且至少要完成一次請求(在這次請求中會調用該方法)。

      問:為什么當我在InProc模式下使用Session會經常丟失?
      答:該問題通常是由于應用程序被回收導致的,因為當使用進程內Session時,Session是保存在aspnet_wp進程中,當該進程被回收Session自然也就沒有了,確定該進程是否被回收可以通過查看系統的事件查看器獲得信息。
      具體信息請參考:
      Session variables are lost intermittently in ASP.NET applications
      http://support.microsoft.com/default.aspx?scid=kb;en-us;Q316148
      在1.0的時候也有一個bug會導致工作進程被回收并重啟,該bug已經在1.1和sp2中修復。
      關于該bug的詳細信息請參考:
      ASP.NET Worker Process (Aspnet_wp.exe) Is Recycled Unexpectedly.
      http://support.microsoft.com/default.aspx?scid=kb;en-us;Q321792

      問:為什么當Session超時或者Abandoned后,新Session的ID和原來的相同?
      答:因為SessionID是保存在客戶端瀏覽器的實例里,當Session超時在服務器重新建立Session時,將使用瀏覽器傳來的SessionID,所以當Session超時后,再重新建立后SessionID并不變。

      問:為什么每次請求的SessionID都不相同?
      答:該問題可能是沒有在Session里面保存任何信息引起的,即程序中任何地方都沒有使用Session。當Session中保存信息之后SessionID將一直和瀏覽器相關,此時的SessionID將不會在變化。

      問:ASP和ASP.NET之間是否可以共享Session?
      答:可以。但是這是一個比較復雜的過程,微軟提供了官方的解決方案,請參考:http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnaspp/html/ConvertToASPNET.asp

      問:什么類型的對象可以保存在Session里?
      答: 這依賴使用的Session的模式,當使用的是進程內(InProc)的Session那么可以輕松的保存任何對象。如果你使用了非InProc的模式, 則只能保存可以序列化和反序列化的對象,如果此時保存的對象不支持序列化,則不能保存到這種模式(非InProc)的Session里。

      問:為什么在Session_End中不能使用Response.Redirect和Server.Transfer方法跳轉頁面?
      答:Session_End是一個在服務器內部激發的事件處理函數。它是基于一個服務器內部的計時器的,在激發該事件時服務器上并沒有相關的HttpRequest對象,因此此時并不能使用Response.Redirect和Server.Transfer方法。

      問:在Session_End中是否可以獲得HttpContext對象?
      答:不行,因為這個事件并沒有和任何的請求(Request)相關聯,沒有基于請求的上下文。

      問:在Web Service中該如何使用Session?
      答: 為了在Web Service中使用Session,需要在Web Service的調用方做一些額外的工作,必須保存和存儲調用Web Service時使用的Cookie。詳細信息請參考MSDN文檔的HttpWebClientProtocol.CookieContainer屬性。 然而,如果你使用代理服務器訪問Web Service由于框架的限制,兩者不能共享Session。

      問:在自定義自己的HttpHandler的時候,為什么不能使用Session?
      答: 在實現自己的HttpHandler的時候,如果希望使用Session必須實現下面的兩個標記接口中的一個: IRequiresSessionState和IReadOnlySessionState,這些接口沒有任何方法需要實現,只是一個標記接口和使用 INamingContainer接口的方法一樣。

      問:當我使用webfarm時,當我重定向到其他的Web服務器時Session為什么會丟失?
      答:詳細信息請參考:
      PRB: Session State Is Lost in Web Farm If You Use SqlServer or StateServer Session Mode
      http://support.microsoft.com/default.aspx?scid=kb;en-us;325056

      問:為什么我的Session在Application_OnAcquireRequestState方法中無效?
      答:Session只有在HttpApplication.AcquireRequestState事件調用以后才會有效。
      詳細信息請參考:
      http://msdn.microsoft.com/library/default.asp?url=/library/en-us/cpguide/html/cpconhandlingpublicevents.asp

      問:如果使用了cookieless,我該如何從HTTP頁面定向到HTTPS?
      答:請嘗試下面的方法:
      String originalUrl = "/fxtest3/sub/foo2.aspx";
      String modifiedUrl = "https://localhost" + Response.ApplyAppPathModifier(originalUrl);
      Response.Redirect(modifiedUrl);

      問:Session在global.asax中的那些事件中有效?
      答:Session只有在AcquireRequestState事件之后有效,該事件之后的事件都可以使用Session。


      問:如何獲得當前Session中保存的所有對象?
      答:可以通過遍歷所有的Session.Keys來獲得。代碼如下:
      ArrayList sessionCollection = new ArrayList();
      foreach (string strKey in Session.Keys){
         sessionCollection.Add(Session[strKey]);
      }

      問:是否可以在不同的應用程序中共享Session?
      答:不能直接共享。可以參考如何在ASP和ASP.NET之間共享Session。

      問:Session.Abandon和Session.Clear有何不同?
      答: 主要的不同之處在于當使用Session.Abandon時,會調用Session_End方法(InProc模式下)。當下一個請求到來時將激發 Session_Start方法。而Session.Clear只是清除Session中的所有數據并不會中止該Session,因此也不會調用那些方 法。

      問:為了可以順序訪問Session的狀態值,Session是否提供了鎖定機制?
      答:Session實現了Reader/Writer的鎖機制:
      當頁面對Session具有可寫功能(即頁面有<%@ Page EnableSessionState="True" %>標記),此時直到請求完成該頁面的Session持有一個寫鎖定。
      當頁面對Session具有只讀功能(即頁面有<%@ Page EnableSessionState="ReadOnly" %>標記),此時知道請求完成該頁面的Session持有一個讀鎖定。
      讀鎖定將阻塞一個寫鎖定;讀鎖定不會阻塞讀鎖定;寫鎖定將阻塞所有的讀寫鎖定。這就是為什么兩個框架中的同一個頁面都去寫同一個Session時,其中一個要等待另一個(稍快的那個)完成后,才開始寫。

      問:Session平滑超時意味著什么?
      答:Session平滑超時意味著只要你的頁面訪問(使用)了Session,超時時間將被刷新(可以理解為重新計時),即從該頁面請求開始,將重新計算超時時間。但是,該頁面不能禁用Session。它會自動的訪問當前頁面的Session,刷新超時時間。

      問:在global.asax中的事件處理函數中Session為什么無效?
      答:依賴于在哪個事件處理函數中使用Session,Session在AcquireRequestState事件之后才有效,該事件之后的所有事件處理函數都可以使用Session,之前的則不能。

      問:當我寫一個依賴于當前應用的Session的組件時,為什么不能直接使用Session["Key"]獲得其值?
      答:Session["Key"]實際上是this.Session["Key"],它是作為Page的一個屬性提供的,所以在你的組件中不能直接使用這個屬性。你可以通過下面的方式使用Session:
      HttpContext.Current.Session["Key"] = "My Seesion Value";

      問:當我使用InProc模式保存Session時,此時的Session是保存在哪里?
      答:不同的IIS的處理方式不同,
      當使用的是IIS5的時候Session是保存在aspnet_wp.exe的進程空間里的。
      當使用的是IIS6時,默認情況下所有的應用程序共享應用程序池,Session保存在w3wp.exe的進程空間中。

      問:Session的超時設置是分鐘還是秒?
      答:是分鐘,默認為20分鐘。

      問:當頁面出現錯誤后我的Session是否將被保存?我需要在Session_End中處理一些清理工作,但是失敗了,為什么?
      答: Session_End只有在Session運行在InProc模式下才會被執行。Session_End使用的帳號是運行aspnet_wp工作進程的 帳號(這個可以在machine.config中設置)。因此,如果在Session_End方法里,使用集成安全性鏈接到SQL,它將使用 aspnet_wp進程的帳號打開鏈接,此時成功與否則依賴于你的SQL的安全性設置。

      問:為什么當我設置cookieless為true是我在重定向的時候會丟失Session?
      答:當使用cookieless時,你必須使用相對路徑替換程序中的絕對路徑,如果使用絕對路徑ASP.NET將無法在URL中保存SessionID。
      例如:將"myDir"mySubdir"default.aspx換成.."default.aspx即可。

      問:如何將SortedList存儲到Session或者Cache里?
      答:請參考下面的方法:
      SortedList x = new SortedList();
      x.Add("Key1", "ValueA");
      x.Add("Key2", "ValueB");
      保存到Session中:
      Session["SortedList1"] = x;
      使用下面方法獲得之:
      SortedList y = (SortedList) Session["SortedList1"];
      Chahe則同理。

      問: 我為什么會獲得這樣的錯誤信息“Session state can only be used when enableSessionState is set to true, either in a configuration file or in the Page directive”?
      答:這個問題可能在一個已經安裝了Microsoft Visual Studio .NET開發環境的機器上,再安裝Window Sharepoint Server(WSS)后出現。
      WSS ISAPI過濾器會處理所有的請求。當你通過虛擬目錄瀏覽一個ASP.NET的應用程序時,ISAPI過濾器不會給文件夾目錄分配URL。
      解決方法是:不要再安裝了WSS的機器上使用Session。
      詳細信息請參考:
      Session state cannot be used in ASP.NET with Windows SharePoint Services
      http://support.microsoft.com/default.aspx?scid=kb;en-us;837376

      問:如何刪除Session變量?
      答:想要刪除Session變量可以使用HttpSessionState.Remove()方法。

      問:是否有辦法知道應用程序的Session在運行時占用了多少內存?
      答:沒有。目前這個值時無法考證的,至少我現在還沒有看到這方面的資料。但是可以通過性能監視器以及程序代碼大概估算出來一個值。

      問:當頁面中是否了frameset,發現在每個frame中顯示頁面的SessionID在第一次請求時都不相同,為什么?
      答:原因是你的frameset是放在一個htm頁面上而不是ASPX頁面。
      在 一般情況下,如果frameset是aspx頁面,當你請求頁面時,它首先將請求發送到Web服務器,此時已經獲得了SessionID,接著瀏覽器會分 別請求Frame中的其他頁面,這樣所有頁面的SessionID就是一樣的,就是FrameSet頁面的SessionID。
      然而如果你使用 Html頁面做FrameSet頁面,第一個請求將是HTML頁面,當該頁面從服務器上返回是并沒有任何Session產生,接著瀏覽器會請求Frame 里面的頁面,這樣這些頁面都會產生自己的SessionID,所以在這種情況下就會出現這種問題。當你重新刷新頁面時,SessionID就會一樣,并且 是最后一個請求頁面的SessionID。

      問:是否可以將不同應用程序的Session保存在相同的SQL Server服務器的不同數據庫上。
      答:可以,請參考:
      FIX: Using one SQL database for all applications for SQL Server session state may cause a bottleneck
      http://support.microsoft.com/default.aspx?scid=kb;en-us;836680

      問:在Session_End是我是否可以獲得有效的HttpSessionState和HttpContext對象?
      答:你可以在這個方法中獲得HttpSessionState對象,可以直接使用Session來訪問即可。但是不能獲得HttpContext對象,因為該事件并沒有和任何請求相關聯,因此不存在上下文對象。

      問:在SQLServer模式下使用Session,為什么我的Session不過期?
      答:在SqlServer模式下,Session的過期是通過SQL Agent的注冊工作完成的,請檢查你的SQL Agent是否運行?

      問:當我設置EnableSessionState為“ReadOnly”后,但是我在InProc模式下依然可以修改Session的值,這是為什么?
      答:即使EnableSessionState標示為ReadOnly,但是在InProc模式下用戶依然可以編輯Session。唯一不同的是,在請求過程中Session將不會被鎖住。

      問:我如何才能避免在鏈接SQL時指定密碼?
      答:使用信任鏈接或者使用加密的鏈接串。有關這方面的詳細信息請參考:
      How To Use the ASP.NET Utility to Encrypt Credentials and Session State Connection Strings
      http://support.microsoft.com/default.aspx?scid=kb;en-us;329290

      問:我在我自己的類中該如何使用Session呢?
      答:可以使用HttpContext.Current.Session方式使用,具體方法如下:
      HttpContext.Current.Session["SessionKey"] = "SessionValue";
      類似的你還可以使用這種方式使用Application對象。

      問:為什么在切換成SQLServer模式后我的請求被掛起了?
      答:檢查在Session里面是否都保存的是可以保存在SQLServer模式下的對象,即這些對象必須支持序列化。

      問:當Session設置成cookieless后會有什么影響?
      答:當把cookieless設置成true時,主要會有下面的約束:
      1、在頁面中不能使用絕對鏈接
      2、在應用程序中在除了Http和Https之間的切換時需要完成一些其他的步驟。
      如果發送一個鏈接給其他人,此時的URL里面將包含Session ID的信息,所以兩個人將公用一個Session。

      問:是否可以將Session保存在數據庫中?
      答:當然可以,詳細信息請參考:http://support.microsoft.com/default

      posted @ 2008-01-31 18:10  love .net FrameWork  閱讀(618)  評論(0)    收藏  舉報
      主站蜘蛛池模板: 91久久国产成人免费观看| 老熟妇乱子交视频一区| 亚洲少妇一区二区三区老| 国产成人精彩在线视频50| 德令哈市| 成人3d动漫一区二区三区| 91孕妇精品一区二区三区| 色综合色综合久久综合频道| 国产小受被做到哭咬床单GV| 国产乱码精品一区二三区| 中国CHINA体内裑精亚洲日本| 精品无码国产污污污免费| 一本色道婷婷久久欧美| 99热精国产这里只有精品| 一本色道久久东京热| 亚洲欧洲精品成人久久曰| 久久一日本综合色鬼综合色| 南京市| 国产精品国三级国产专区| 久热这里有精品视频播放| 综合图区亚洲欧美另类图片| 亚洲人成电影在线天堂色| 中文字幕色av一区二区三区| 亚洲中文字幕有综合久久| 色色97| 她也色tayese在线视频| 亚洲悠悠色综合中文字幕| japan黑人极大黑炮| 无码伊人66久久大杳蕉网站谷歌 | 成人免费A级毛片无码片2022| A级日本乱理伦片免费入口| 欧洲美熟女乱av在免费| 国模少妇无码一区二区三区| 国产色一区二区三区四区| 亚洲成人av免费一区| 国产不卡免费一区二区| 成人精品区| 大香伊蕉在人线国产免费| 日韩精品久久久肉伦网站| 永久免费无码网站在线观看| 免费十八禁一区二区三区|