关于asp.net Session丢失问题的总结

news/2024/7/6 3:57:02

更完整的关于asp.net session 丢失问题的帖子请见下文:

理解Session State模式+ASP.NET SESSION丢失FAQ [翻译]


asp中Session的工作原理:
asp的Session是具有进程依赖性的。ASP Session状态存于IIS的进程中,也就是inetinfo.exe这个程序。所以当inetinfo.exe进程崩溃时,这些信息也就丢失。另外,重起或者关闭IIS服务都会造成信息的丢失。

asp.net Session的实现
asp.net的Session是基于HttpModule技术做的,HttpModule可以在请求被处理之前,对请求进行状态控制,由于Session本身就是用来做状态维护的,因此用HttpModule做Session是再合适不过了。

原因1:
bin目录中的文件被改写,asp.net有一种机制,为了保证dll重新编译之后,系统正常运行,它会重新启动一次网站进程,这时就会导致Session丢失,所以如果有access数据库位于bin目录,或者有其他文件被系统改写,就会导致Session丢失

原因2:
文件夹选项中,如果没有打开“在单独的进程中打开文件夹窗口”,一旦新建一个窗口,系统可能认为是新的Session会话,而无法访问原来的Session,所以需要打开该选项,否则会导致Session丢失

原因3:
似乎大部分的Session丢失是客户端引起的,所以要从客户端下手,看看cookie有没有打开

原因4:
Session的时间设置是不是有问题,会不会因为超时造成丢失

原因5:
IE中的cookie数量限制(每个域20个cookie)可能导致session丢失

原因6:
使用web garden模式,且使用了InProc mode作为保存session的方式

解决丢失的经验
1. 判断是不是原因1造成的,可以在每次刷新页面的时候,跟踪bin中某个文件的修改时间
2. 做Session读写日志,每次读写Session都要记录下来,并且要记录SessionID、Session值、所在页面、当前函数、函数中的第几次Session操作,这样找丢失的原因会方便很多
3. 如果允许的话,建议使用state server或sql server保存session,这样不容易丢失
4. 在global.asa中加入代码记录Session的创建时间和结束时间,超时造成的Session丢失是可以在SessionEnd中记录下来的。
5. 如果有些代码中使用客户端脚本,如javascript维护Session状态,就要尝试调试脚本,是不是因为脚本错误引起Session丢失

参考:
[1] http://jinglecat.cnblogs.com/archive/2005/11/14/275587.aspx
[2] http://www.0dsf.com/bbs/dispbbs.asp?boardID=30&ID=6032&page=5
[3] http://spaces.msn.com/eparg/Blog/cns!1pnPgEC6RF6WtiSBWIHdc5qQ!447.entry
[4] http://jinlinc.cnblogs.com/archive/2005/11/29/287181.aspx
[5] http://blog.joycode.com/ghj/archive/2004/06/23/25521.aspx
[6] http://www.365base.com/Article/343/347/2005/2005091534671.html

大家如果还有其他的经验,可以写在回复中,我会即时更新的

 





http://www.niftyadmin.cn/n/3656329.html

相关文章

从MSN Messenger看软件行为

软件行为从一定意义上讲,就是为了保证软件的可用性和用户界面友好,这段时间在使用msn时发现了一些很有意思的小细节,拿出来和大家探讨一下。当然可能有些朋友会认为这些软件行为是应该的,其实软件行为的意义并不在于行为本身&…

C++类大小

一个空类class A{};的大小为什么是1&#xff0c;因为如果不是1&#xff0c;当定义这个类的对象数组时候A objects[5]; objects[0]和objects[1]就在同一个地址处&#xff0c;就无法区分。 单继承 #include<iostream> using namespace std; class A { public:virtual void…

随想——程序员与测试员

在程序员和测试员之间&#xff0c;似乎总存在着一道隔离栏&#xff0c;可能是我太敏感了吧……先从目前公司里的分工说起&#xff0c;听过许多朋友向我诉苦&#xff0c;从需求分析到产品交付&#xff0c;在小公司一个项目通常都是一个人负责的&#xff0c;甚至在一些大公司也是…

如何在centos环境下运行.exe文件

首先要了解一下Wine&#xff1a; Wine &#xff08;“Wine Is Not an Emulator” 的首字母缩写&#xff09;是一个能够在多种 POSIX-compliant 操作系统&#xff08;诸如 Linux&#xff0c;Mac OSX 及 BSD 等&#xff09;上运行 Windows 应用的兼容层。 Wine (Wine Is Not an…

ASP.NET中大结果集的分页[翻译]

原文地址&#xff1a;http://www.codeproject.com/aspnet/PagingLarge.asp作者&#xff1a;Jasmin Muharemovic 译者&#xff1a;Tony Qu(来自BluePrint翻译团队)下载&#xff1a;PagingTest Solution (C#) - 55.8 KbPaging_Procedures SQL script - 2.48 KbPaging_LargeTable …

[翻译计划]脚本引擎实现

原文标题&#xff1a;Implementing A Scripting Engine原文地址&#xff1a;http://www.flipcode.com/articles/scripting_issue01.shtml作者&#xff1a;Jan Niestadt目录Implementing A Scripting Engine - Part 1 - Overview [Tony Qu][完成]Implementing A Scripting …

[翻译]脚本引擎实现 - 第一部分 总揽

原文地址&#xff1a;http://www.flipcode.com/articles/scripting_issue01.shtml 作者&#xff1a;Jan Niestadt译者&#xff1a;Tony Qu备注&#xff1a;本文语言十分口语化&#xff0c;如果觉得读起来不舒服&#xff0c;可以告诉我&#xff0c;我会做适当修订。介绍你的脚本…

linux远程登陆命令(无工具)

方法一&#xff1a; telnet命令 网络应用 telnet命令用于登录远程主机&#xff0c;对远程主机进行管理。telnet因为采用明文传送报文&#xff0c;安全性不好&#xff0c;很多Linux服务器都不开放telnet服务&#xff0c;而改用更安全的ssh方式了。但仍然有很多别的系统可能采用…