分类广告


推荐文章

  • 没有找到任何内容!
您当前的位置:中国站长下载网络编程NET专区 → 文章内容

在asp.net中使用session常见问题集锦 5

  • 作者:佚名    来源:不详    发布时间:2007-6-30 10:21:26
  • 字体大小:
     将请求发送到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后会有什么影响?