* 说Session大家都知道也都用过(做asp.net我遇到过没用过Cookies的,还没遇到过没用过Session的),Session的保存方式默认是在内存中,更确切的说是在
asp.net的进程中,这种方式是默认的保存方式即InProc方式,在web.config里面可以进行配置。这种方式由于和应用程序在同一进程中,所以有时会发生丢失的
情况。有没有解决办法呢?答案是有的。
一般常用的Session保存方式还有StateServer和SQLServer,StateServer是一个单独的进行,较之InProc要稳定的多。而SQLServer则是可以持久的保存Session。
还有一个平时大家都说关闭浏览器Session便会丢失,其实不是这样的。Session都是有个超时时间的(TimeOut),因为Web本身就是无连接的。服务器怎么可能知道客户关闭了浏览器?即而怎么可能随之关闭Session,下面讲一下为什么表面上浏览器关闭了Session就会“丢失”。Session在服务器上是以散列表结构保存的,并且每个会话Session服务哭都会生成一个唯一ID,又名SessionID。而自定义的Session 键值是以哈希表形式存储在相应的SessionID下面的。比如
用户A
SessionID:goly4y550qfsmy554cm3k155
Key:LoginOK Value:true
Key:UserName Value:春哥
用户B
SessionID:v4h40355mnhk3k451nfibj55
Key:LoginOK Value:true
Key:UserName Value:曾哥
从上面的例子就可以看出为什么用户A登录后的 Session[“UserName”]是春哥,而用户B登后的Session[“UserName”]是曾哥了。
话接上题,因为每次会话请求都会生成一个新的唯一的SessionID,所以当关闭浏览器的时候,当前的SessionID还是存在于服务器上的,Session并没有丢,但是重新又建立请求时又生成了新的SessionID所以以前的Session当然是取不到的了。(IE8打开页面A后再打开页面B是同一个SESSIONid,所以会发生双开覆盖用户信息的问题。可以通过文件-新会话页面方式开启新的会话页面。而IE7以下不会这样情况)。
最后说一下基本上Session不能共享也是因为这样的原因即每个请求都会是一个新的会话SessionID。