日期:2011-10-10  浏览次数:20934 次

当开发人员使用Session变量时必须要求客户端浏览器支持接受cookies,当ASP开始一个Session,它将送一个cookies到客户端并带一个标示(SessionID).通过这个标示,ASP以后将可以确认Session并且因此来保持状态。所以,当你使用Session变量前,你需要确认cookies是否被接受。这里我讲解两个方法:


方法一:
无论何时你在两页之间,有一个非常简单可靠的方法:请求一个SessionID在第一页,传递它到下一页。与这一页请求到的SessionID比较。相同说明客户端浏览器接受Cookies;不同则不接受。很简单吧。
比如你可以在第一页中放一个(hiddenfield),并把SessionID写入它。提交后,从页面数据中取出SessionID.像这样:

<formname="Form1"method="post"action="sessions2.asp">
UserName:<inputname="username"><br>
Password:<inputname="userpassword">
<inputtype="hidden"name="theSessionID"value="<%=Session.SessionID%>"><br>
<inputtype="submit"value="Submit">
</form>

在第二页中我们来判断SessionID是否相同。
<%
dimtheSessionID
theSessionID=Request.Form("theSessionID")
IftheSessionID=Session.SessionIDThen
"当二者相等时,则cookie功能开启
Response.Write"Cookie已开启"
Else
"若二者相等时,则cookie功能关闭
Response.Write"Cookie没有开启!"
EndIf
%>


方法二:
也可用这种方法,首先在一个页面里写入一个cookie,如:
<%
Response.Cookies("status")="onoroff"
%>
在第二页里读出此cookie:
<%
ifRequest.Cookies("status")=""then
"当cookies("status")里没有值时,则cookie功能没有开启
Response.Write"Cookie没有开启!"
else
"当cookies("status")里有值时,则cookie功能开启
Response.Write"Cookie已开启"
endif
%>