也许很多asp开发者都会遇到这样的情况:在会话期间(session)无故丢失sessio n。换而言之,丢失了SessionID,同样session级的变量也会丢失。
很多session丢失的原因是因为错误的程序或者是错误的虚拟目录结构。
SessionID 的改变有下面几个原因。
原因一:
Netscape的浏览器会认为"/App/user.asp"跟"/app/user.asp"是两个不同的程序。它会自动地开始一个新的会话期(new session)。所以,才你的网站上一定要统一字母的大小写。
原因二:
另外一个是原因是 Session.Timeout 的值。
Timeout这个属性是用来设置Session的超时时间的,一分钟为单位。假如一个用户,在一个Timeout的时间内没有刷新或者请求页面,那么会话就会结束(the se ssion ends)。当你再次请求页面的时候,一个新的会话有会开始。
确信Timeout的值,是分钟的。
格式: Session.Timeout [ = nMinutes]
原因三:
假如用户把他们的浏览器的cookie关了,当然session就不能保持。因为session的保持是要靠cookie的。
要保持Session的状态,浏览器就必须支持cookie,而且在打开的状态。你当然可以用其他的方法
原因四:
常犯的错误就是,建立了错误的目录结构。像下面的目录结构:
root 放了global.asa
\virtual_root 没有global.asa
\another_virtual_root 没有global.asa
调用两个virtual roots的页面,就会执行相同的global.asa(root上的那个)
另外的一个目录结构:
root 没有global.asa
\virtual 放了global.asa
\another_virtual_root 另外一个global.asa
每一个不同目录下的global.asa都会各自执行,当然执行的代码就不同了。不过如果里面的代码一样,就令当别说。:)
所以你在请求不同目录下页面,将会导致不同的global.asa被执行。不同的变量被调用,不同的session id被建立....之前的有用的信息都被破坏了。
下面是详细的解释:
当你先浏览子虚拟程序上的页面(child virtual application),然后再去浏览子虚拟程序的上一级的父虚拟程序(parent virtual root)的页面。那些变量就会丢失、破坏。看下面的表格:
请求 子程序1丢失 子程序2丢失
先请求 Root 不会 不会
只在子程序1之前请求 Root 不会 会
只在子程序2之前请求 Root 会 不会
最后请求 Root 会 会
【相关推荐】
1. ASP免费视频教程
Atas ialah kandungan terperinci 教你解决ASP session丢失的方法. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!