标题:突然想到一个跨站(跨域名)传递session的思路,高手看看能不能行的通.
只看楼主
无根泉
Rank: 2
等 级:新手上路
威 望:4
帖 子:853
专家分:0
注 册:2004-11-4
得分:0 
用数据库来存储用户信息,
sub online(id)
set rs=server.createobject("adodb.recordset")
sql="select * from online where id="&id
rs.open sql,conn,3,2
if rs.eof then
response.write"请登录后再来!"
online=false
else
online=ture
end if
rs.close
set rs=nothing
end sub
这样把用户的ID传过去就行了,
if online(request.querystring("id"))=true then
response.write"欢迎光临!"
end if
版主看看这样行不行!

我很菜,但我很努力!
2005-06-28 08:47
静夜思
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:济南的冬天
等 级:管理员
威 望:11
帖 子:8842
专家分:2567
注 册:2004-3-25
得分:0 
如果一个用户在线,别人用他的ID进行判断得到的结果也是online=ture

畅所欲言
2005-06-28 08:53
islet
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:89
帖 子:6548
专家分:0
注 册:2005-1-28
得分:0 
Response.Cookies("user")=Request.Form("UserName")

user=Request.Cookies("CookieName")

if user="" or user=null then response.Redirect("login.asp")

没有Cookies 就重新登陆
2005-06-28 10:33
islet
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:89
帖 子:6548
专家分:0
注 册:2005-1-28
得分:0 
原文出处:http://www.asptoday.com/articles/19990915.htm    实际上,在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的扩展性是无穷的,这篇文章仅仅是抛砖引玉。
2005-06-28 10:33
jeeffeer
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2006-2-22
得分:0 

这个是一个办法,但总觉得不妥,能不能提供一个比较满意的办法!
我现在做的项目需要这样的登陆。
谢谢各位大家,请大家帮个忙呀!

2006-02-22 11:20
水露
Rank: 1
等 级:新手上路
帖 子:143
专家分:0
注 册:2005-8-3
得分:0 
与session对像相似的另一个对象application,可不可以考虑将它的信息存在一个后端数据库中.以实现跨越多台服务器.

[此贴子已经被作者于2006-2-22 13:39:24编辑过]


2006-02-22 13:30
sman
Rank: 1
等 级:新手上路
帖 子:44
专家分:0
注 册:2006-2-17
得分:0 

如果是二级域名可以看看cookies.domain属性可以做到.
不过Cookies是要加密的....其实就是论坛Cookies登录及在线支付一个原理...
看看在线支付原理就知道了..
发送方和接收方"密钥"是一样的..定期修改的...
发送数据时
验证字段=md5(用户ID&用户名&......&密钥)
传值时userid=用户ID&username=用户名&key=验证字段

接收时用相同的方法验证就是了..
注:MD5最好修改一下..加密次数,位数...

就这样..


http://www./
2006-02-22 15:13



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-21677-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.238185 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved