ASP中Cookie使用指南

%@ LANGUAGE=”VBscript” % % RequestName =
Request.Form(“Name”)RequestLeaveMeAlone = Request.Form(“LeaveMeAlone”)If
RequestName “” or RequestLeaveMeAlone “” then

我自己曾想写一篇关于Cookie的文章,特别是Client端Script同Server端ASP通过Cookie交
互的问题可能会困扰大家。其实是如果你对Cookie有深入的理解,特别是对域和路径的概念
比较清晰的话,就不会有问题了。
另外想提示的一点是request.ServerVariables(“HTTP_COOKIE”)得到Cookie和
Request.Cookies得到的结果可能会有所不同。大家思考一下为什么,会对ASP的学习提高有
所帮助的。

废话不多说,这几天在研究动网整合个人网站,在百度搜索了两天,发现就TM那几篇文章,按照文章弄的死去活来就是么搞好,“人生最痛苦的事就是你通宵去做事情,却没做好。。。”经过几天奋战终于攻破,所谓功夫不负有心人,大概就是这样。现在公布程序:

‘ 在同一个页面中检查表单变量. Response.Cookies(“MySiteVisitorName”) =
RequestName Response.Cookies(“MySiteVisitorName”).Expires = #January
01, 2008# Response.Cookies(“MySiteLeaveMeAlone”) = RequestLeaveMeAlone
Response.Cookies(“MySiteLeaveMeAlone”).Expires = #January 01, 2008#

Request.Cookies,粒子:

参考网站:第一货源    免费网店代理

‘ 如果表单变量存在,就创建Cookie,并设置到期时间.End if

<TABLE BORDER=”2″>
<THEAD>
<TH>Cookie Name</TH>
<TH>Cookie Value</TH>
<TH>Cookie HasKeys</TH>
</THEAD>
<%
Dim Item
For Each Item in Request.Cookies
%>
<TR>
<TD><% = Item %></TD>
<TD><% = Request.Cookies(Item) %></TD>
<TD><% = Request.Cookies(Item).HasKeys %></TD>
</TR>
<TR>
<%
  If Request.Cookies(Item).HasKeys Then
    For Each strSubKey In Request.Cookies(Item)
%>
<TD>&bnsp;</TD>
<TD>&bnsp;</TD>
<TD><% = Request.Cookies(strKey)(strSubKey) %></TD>
<%
Next
End If
Next
%>
</TABLE>

/根目录:index.htmi、chklogin2.asp、conn.asp

VisitorName = request.Cookies(“MySiteVisitorName”)LeaveMeAlone =
request.Cookies(“MySiteLeaveMeAlone”)

request.ServerVariables(“HTTP_COOKIE”),粒子:
<TABLE BORDER=”2″>
<THEAD>
<TH>Cookie Name</TH>
<TH>Cookie Value</TH>
</THEAD>
澳门新葡萄京娱乐场,<%
Dim Item,sp,i,d
sp = split(request.ServerVariables(“HTTP_COOKIE”),”; “,-1,1)
` Loop through the cookie collection displaying each cookie we find

/根目录/bbs/:动网程序

‘ 读取Cookie.

For i=0 to UBound(sp)
d = split(cstr(sp(i)),”=”,-1,1)
%>
<TR>
<TD><% = d(0) %></TD>
<TD><% if UBound(d)=1 then Response.Write(d(1)) else Response.Write ” ” %
></TD>
</TR>
<%
Next
%>
</TABLE>

1首先修改cookie 通用名称

If VisitorName =”” and LeaveMeAlone =”” then

重粒子@Y2K0814

下面是甘冀平翻译的<ASP中Cookie使用指南>
原文出处:

   实际上,在web开发中,cookie仅仅是一个文本文件,当用户访问站点时,它就被存储
在用户使用的计算机上,其中,保存了一些信息,当用户日后再次访问这个站点时,web可
以将这些信息提取出来。

   尽管现在听起来cookie没有什么激动人心的,但实际上利用它,你能实现许多有意义
的功能!比如说:你可以在站点上放置一个调查问答表,询问访问者最喜欢的颜色和字体,
然后根据这些定制用户的web界面。并且,你还可以保存访问者的登录密码,这样,当访问
者再次访问这个站点时,不用再输入密码进行登录。

   当然,cookie也有一些不足。首先,由于利用cookie的功能可以编程实现一些不良企
图,所以大多数的浏览器中都有安全设定,其中可以设置是否允许或者接受cookie,因此这
就不能保证随时能使用cookie。再者,访问者可能有意或者无意地删除cookie。当访问者的
机器遇到“蓝屏”死机时,或者重新格式化硬盘、安装系统后,原来保存的cookie将全部丢
失。最后一点,有一些最初始的浏览器并不能支持cookie。

   利用cooklie能做什么?

   有2种使用cookie的基本方式:
1、将cookie写入访问者的计算机(使用 RESPONSE 命令)
2、从访问者的计算机中取回cookie(使用 REQUEST 命令)

   创建cookie的基本语法

   Response.Cookies(“CookieName”)=value

   执行下面的代码将会在访问者的计算机中创建一个cookie,名字=VisitorName,值=
Ken
Response.Cookies(“VisitorName”)=”Ken”

   执行下面的代码将会在访问者的计算机中创建一个cookie,名字=VisitorName,值=
表单中UserName的值
Response.Cookies(“VisitorName”)=Request.Form(“UserName”)

   读取cookie的基本语法 

   Request.Cookies(“CookieName”) 

   可以将Request值当作一个变量看待,执行下面的代码,将取回名字为KensCookie的
cookie值,并存入变量MyVar:
MyVar=Request.Cookies(“KensCookie”)

   执行下面的代码,将判断名字为KensCookie的cookie值是否为“Yes”:
If Request.Cookies(“KensCookie”)=”Yes” then

   功能丰富的cookie 

   你可以扩展上面的代码成为Cookie子关键值(CookieSubName),代码如下:
Response.Cookies(“VisitorName”)(“FirstName”)=”Ken” 
Response.Cookies(“VisitorName”)(“LastName”)=”Baumbach” 

   讲解例子前,最后讨论2个概念:命令约定和使用到期时间。

   命名约定

   同其他变量的命名一样,合适地、独特地命名cookie,有利于在程序中前后连贯地使
用它。你可以使用下面的1个或者2个cookie属性进行cookie变量的命名:

   域属性(Domain):域属性表明cookie由哪个网站产生或者读取,默认情况下,
cookie的域属性设置为产生它的网站,但你也可以根据需要改变它。相关代码如下:
Response.Cookies(“CookieName”).Domain = “www.mydomain.com” 

   路径属性(Path):路径属性可以实现更多的安全要求,通过设置网站上精确的路
径,就能限制cookie的使用范围。例如:
Response.Cookies(“CookieName”).Path = “/maindir/subdir/path” 

   使用到期时间

   通常情况下,当浏览器关闭时,一个cookie就不存在了。但是在许多时候,比如下面
将要讨论的web站点例子,我们希望能更长时间地在访问者的计算机上保存cookie。很幸
运,有这样的实现方法。下面的代码,就可以设置cookie的使用到期时间为2010年1月1
日: 
Response.Cookies(“CookieName”).Expires=#January 01, 2010#

   执行下面的代码,将设定cookie的过期时间为“cookie的创建时间+365日”:
Response.Cookies(“CookieName”)=Date+365

   使用cookie的实际例子(非常精彩)

   现在开始讨论实际的例子。假设:你想做一个调查,每个人初次访问时需要填写好信
息,但是当日后再访问时,就不需要再那么做。利用cookie,就可以非常圆满地解决这个问
题,而大可不必用到数据库。

< %@ LANGUAGE=”VBSCRIPT” %  >
< % 
Survey=Request.Cookies(“KensSurvey”)
If Survey =”” then
  Response.Cookies(“KensSurvey”)=”x”
  Response.Cookies(“KensSurvey”).Expires=#January 01, 2010#
  Response.Redirect “survey.asp”
Else
`rest of the page
End if
% >
   好,下面开始从头讨论上面的代码。

   首先,初始设置页面,并读取名字为KensSurvey的cookie值:

< %@ LANGUAGE=”VBSCRIPT” % >
< % 
Survey=Request.Cookies(“KensSurvey”)
   然后,判断是否已经存在cookie值:

If Survey =”” then
   如果不存在, 就创建并设置cookie,并转到页面survey.asp。 当下一次访问时,因
为存在cookie值,就不会再转到survey.asp 页面。

   Response.Cookies(“KensSurvey”)=”x”
   Response.Cookies(“KensSurvey”).Expires=#January 01, 2010#
   Response.Redirect “survey.asp”
   如果cookie已经存在,那么访问者将执行页面中剩余的代码:

`rest of the page

End if
% >
   例子2 

   这里有另外一个简单的例子:当访问者第1次浏览某个站点时,向他们显示欢迎信
息。代码如下:

< %@ LANGUAGE=”VBSCRIPT” % >
< % 
RequestName = Request.Form(“Name”)
RequestLeaveMeAlone = Request.Form(“LeaveMeAlone”)
If RequestName <  >”” or RequestLeaveMeAlone <  >”” then
  Response.Cookies(“MySiteVisitorName”) = RequestName
  Response.Cookies(“MySiteVisitorName”).Expires = #January 01, 2010#
  Response.Cookies(“MySiteLeaveMeAlone”) = RequestLeaveMeAlone
  Response.Cookies(“MySiteLeaveMeAlone”).Expires = #January 01, 2010#
End if    
VisitorName = request.cookies(“MySiteVisitorName”)
LeaveMeAlone = request.cookies(“MySiteLeaveMeAlone”)

If VisitorName =”” and LeaveMeAlone =”” then
% >
  < HTML > < HEAD > < /HEAD >
  < body bgcolor=”#ccffff” text=”black” link=”navy” vlink=”purple” >
  < DIV ALIGN=”CENTER” >
  < form action=”index.asp” method=”POST” >
  < H2 >Let`s be friends< /H2 >
  What`s your name (leave blank and hit the Submit button if you don`t want us 
to know)? 
  < input type=”text” name=”name” >< BR >< BR >
  < input type=”hidden” name=”LeaveMeAlone” value=”x” >
  < input type=”submit” value=”Submit” >
  < /FORM >
  < /DIV >
  < /BODY >
< %
End if
If VisitorName <  > “” then
   Response.write “Hi, ” & VisitorName & “!  I hope you are having a great day!”
End if
`rest of the page
% >
   好,现在来看看上面的代码实现执行了什么。首先,设置页面。然后,检查表单变量
(在同一个页面中)。如果表单变量存在,就创建cookie,并设置到期时间。

< %@ LANGUAGE=”VBSCRIPT” % >
< % 
RequestName = Request.Form(“Name”)
RequestLeaveMeAlone = Request.Form(“LeaveMeAlone”)
If RequestName <  >”” or RequestLeaveMeAlone <  >”” then
  Response.Cookies(“MySiteVisitorName”) = RequestName
  Response.Cookies(“MySiteVisitorName”).Expires = #January 01, 2010#
  Response.Cookies(“MySiteLeaveMeAlone”) = RequestLeaveMeAlone
  Response.Cookies(“MySiteLeaveMeAlone”).Expires = #January 01, 2010#
End if    

   接着,读取cookie:

VisitorName = request.cookies(“MySiteVisitorName”)
LeaveMeAlone = request.cookies(“MySiteLeaveMeAlone”)
   如果cookie在访问者的计算机上不存在,就创建一个表单,询问相关信息:

If VisitorName =”” and LeaveMeAlone =”” then
% >
  < HTML >
  < HEAD >
  < /HEAD >
  < body bgcolor=”#ccffff” text=”black” link=”navy” vlink=”purple” >
  < DIV ALIGN=”CENTER” >
  < form action=”index.asp” method=”POST” >
  < H2 >Let`s be friends< /H2 >
  What`s your name (leave blank and hit the Submit button if you don`t want us 
to know)? 
  < input type=”text” name=”name” >< br >< br >
  < input type=”hidden” name=”LeaveMeAlone” value=”x” >
  < input type=”submit” value=”Submit” >
  < /FORM >
  < /DIV >
  < /BODY >
< %
End if
   如果cookie已经存在,并且用户名字存在,就显示给访问者一个欢迎界面,然后执行
其余的代码。

If VisitorName <  > “” then
  Response.write “Hi, ” & VisitorName & “!  I hope you are having a great day!”
End if
`rest of the page
% >
   尽管上面的这个例子很简单,但可以从中扩展许多富有创造力的应用。你可以在表单
中加入许多功能,以便定制化web站点。你还可以让访问者定制网站的色彩、字体,以至于
其他web元素。有可能的话,你可以询问访问者的生日,当访问者在那一天来访时,你就可
以显示“生日快乐”的信息给他。

   如你所见,cookie的扩展性是无穷的,这篇文章仅仅是抛砖引玉。

文件路径:bbsincDv_ClsMain.asp 
第83行修改Forum_sn和CacheName,不要的注释掉

‘ 如果用户机子上不存在该Cookie,就创建一个表单询问相关信息.% html head

  ‘Forum_sn=”DvForum
8.3″‘如果一个虚拟目录或站点开多个论坛,则每个要错开,不能定义同一个名称
  ‘Forum_sn=Forum_sn & “_” &
Request.servervariables(“SERVER_NAME”)
  Forum_sn=”no1g”‘如果一个虚拟目录或站点开多个论坛,则每个要错开,不能定义同一个名称
  CacheName=”no1g”‘如果一个虚拟目录或站点开多个论坛,则每个要错开,不能定义同一个名称

title随风起舞欢迎你!/title

2修改cookie全站通用路径,动网限制只能在bbs目录下访问cookie,我们膝盖全站通用,有8处要修改

/head body bgcolor=”#ccffff” text=”black” link=”navy” vlink=”purple”
DIV ALIGN=”CENTER” form action=”index.asp” method=”POST” H2
欢迎光临精彩春风 /H2 您的网上昵称是 input type=”text” name=”name”
(您可以选择不回答而直接点击”发送”按钮) br br input type=”hidden”
name=”LeaveMeAlone” value=”x” input type=”submit” value=”发送” /FORM
/DIV /body %End ifIf VisitorName “” then Response.write “欢迎您,” &
VisitorName & “! 这儿就是您的家!”

①两个地方打开inc/Dv_ClsMain.asp 分别寻找
Response.Cookies(Forum_sn).path 和
Response.Cookies(Dvbbs.Forum_sn).path 将右侧的值均替换为”/” ,例:
Response.Cookies(Forum_sn).path=”/”

‘ 如果Cookie和用户名都已存在,则显示一个欢迎页面.End if’ 结束其余代码.

② 三个地方打开login.asp 寻找
Response.Cookies(Dvbbs.Forum_sn).path=Dvbbs.cookiepath
应该共有三个,其中一个是:Response.Cookies(Dvbbs.Forum_sn).path =
Dvbbs.cookiepath(等号两旁有空格) 替换为:
Response.Cookies(Dvbbs.Forum_sn).path=”/”

%

③ 一个地方打开logout.asp 寻找
Response.Cookies(Dvbbs.Forum_sn).path=Dvbbs.cookiepath
第27行应该只有一个替换为: Response.Cookies(Dvbbs.Forum_sn).path=”/”
至此,修改完毕,即可以达到cookies全站通用的目的了

[1]

④两个地方 打开reg.asp
寻找Response.Cookies(Dvbbs.Forum_sn).path=Dvbbs.cookiepath
替换Response.Cookies(Dvbbs.Forum_sn).path = “/”

3根目录登录文件index.html

<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN”
“”>
<html xmlns=””>
<head>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″
/>
<title>首页</title>
</head>

<body>
<a href=”bbs/index.asp”>论坛</a>
<form id=”form1″ name=”form1″ method=”post”
action=”chklogin2.asp”>
 账户:<input type=”text” name=”username” />
 密码:<input type=”password” name=”password” />
 <input type=”submit” name=”Submit” value=”提交” />
</form>
</body>
</html>

4登录验证文件chklogin2.asp

<!–#include file=”conn.asp”–>
<!–#include file=”bbs/inc/md5.asp”–>
<!–#include file=”bbs/inc/const.asp”–>
<%
dim username,UserPassword,comeurl
username=trim(request.Form(“UserName”))
UserPassword=trim(request.Form(“password”))
response.write “提交”&username&”<br />”
response.write “提交”&UserPassword&”<br />”

if username=”” then
response.Write “<script
LANGUAGE=’javascript’>alert(‘登录失败,请输入用户名!’);location.href='”&comeurl&”‘;</script>”
conn.Close
set conn=nothing
response.end
end if

if UserPassword=”” then
response.Write “<script
LANGUAGE=’javascript’>alert(‘登录失败,请输入密码!’);location.href='”&comeurl&”‘;</script>”
conn.Close
set conn=nothing
response.end
end if

set rs=server.CreateObject(“adodb.recordset”)
rs.Open “Select * From [Dv_User] Where UserName='”&username&”‘”
,conn,1,3
‘如果用户存在
if not(rs.bof and rs.eof) then
    if rs(“UserPassword”)=MD5(UserPassword) then
  ‘设置用户登录cookie
  response.write “前台提交! <a
href=’bbs/index.asp’>论坛</a>”
  Response.Cookies(“no1g”).path=”/”
  response.Write
“userid:”&rs(“userid”)&”-“&”userclass:”&rs(“userclass”)&”-“&”username:”&rs(“username”)&”-“&”TruePassWord:”&rs(“TruePassWord”)&”-“
  Response.Cookies(“no1g”)(“userid”) = rs(“userid”)
  Response.Cookies(“no1g”)(“usercookies”) = “2”
  Response.Cookies(“no1g”)(“userclass”) = rs(“userclass”)
  Response.Cookies(“no1g”)(“username”) = rs(“username”)
  Response.Cookies(“no1g”)(“userhidden”) = 2
  Response.Cookies(“no1g”)(“password”) = rs(“TruePassWord”)
  Response.Cookies(“no1g”)(“StatUserID”) =
Response.Cookies(“no1g”)(“StatUserID”)
  Response.Cookies(“upNum”)=0
  Response.Cookies(“no1g”).Expires=Date+31

  
 
  rem 清除图片上传数的限制
  Response.Cookies(“upNum”)=0
  response.write “登录成功! <a
href=’bbs/index.asp’>论坛</a>”

 else
  response.write “<script
LANGUAGE=’javascript’>alert(‘您输入的密码有误!’);location.href='”&comeurl&”‘;</script>”
  response.end
 end if
 ‘跳转到你登陆的页面
else
 response.write “<script
LANGUAGE=’javascript’>alert(‘您输入的用户不存在!’);location.href='”&comeurl&”‘;</script>”
 response.end
end if

rs.Close
set rs=nothing

conn.Close
set conn=nothing
%>

5数据库链接文件 conn.asp

<%
dim conn,connstr,startime,sundxDB,rs,UserAgent
startime=timer()
UserAgent = Trim(Lcase(Request.Servervariables(“HTTP_USER_AGENT”)))
If InStr(UserAgent,”teleport”) > 0 or InStr(UserAgent,”webzip”) >
0 or InStr(UserAgent,”flashget”)>0 or InStr(UserAgent,”offline”)>0
Then
 Response.Write
“请不要采用teleport/Webzip/Flashget/Offline等工具来浏览商城!”
 Response.End
End If

‘连接数据库
sundxDB=”bbs/Data/Dvbbs83.mdb”
connstr=”Provider=Microsoft.Jet.OLEDB.4.0;Data Source=” &
Server.MapPath(“”&sundxDB&””)
On Error Resume Next
 Set conn = Server.CreateObject(“ADODB.Connection”)
 conn.open connstr
 If Err Then
  err.Clear
  Set Conn = Nothing
  Response.Write “数据库连接出错,请检查Conn.asp中的数据库指向。”‘
  Response.End
 End If
%>

希望对大家有帮助,同时请尊敬他人劳动成果,转请注明来源联系本人请到
转:

发表评论

电子邮件地址不会被公开。 必填项已用*标注