Asp中如何设计跨越域的Cookie

2016-02-19 22:05 34 1 收藏

每个人都希望每天都是开心的,不要因为一些琐事扰乱了心情还,闲暇的时间怎么打发,关注图老师可以让你学习更多的好东西,下面为大家推荐Asp中如何设计跨越域的Cookie,赶紧看过来吧!

【 tulaoshi.com - Web开发 】

  Cookie简介

  首先,我们对Cookie做一个简单的介绍,说明如何利用ASP来维护cookie。

  Cookie是存储在客户端计算机中的一个小文件,这就意味着每当一个用户访问你的站点,你就可以秘密地在它的硬盘上放置一个包含有关信息的文件。这个文件几乎可以包含任何你打算设置的信息,包括用户信息、站点状态等等。这样的话,就有一个潜在的危险:这些信息有可能被黑客读取。为了防止这个问题的发生,一个有效的办法就是cookie只能被创建它的域所存取。这就是说:比如ytu.edu.cn只能访问ytu.edu.cn创建的cookie。通常来讲,这没有什么问题;但是,如果需要两个不同域上的两个不同站点共享保存在cookie中的用户信息,该如何处理呢?当然可以选择复制用户信,但是,如果你需要用户只能在一个站点上注册,并且自东成为另外一个站点的注册用户呢?或者,两个站点共享一个用户数据库,而又需要用户自动登录呢?这时候,跨越域共享cookie是最好的解决方案。
 
  这里,先看一些ASP处理cookie的代码,以便以后便于引用参考。

  
  '创建Cookie

  Response.Cookies("MyCookie").Expires=Date+365

  Response.Cookies("MyCookle").Domain="mydomaln.com"

  Response.Cookies("MyCookle")("Username")=strUsername

  Response.Cookies("MyCookle")("Password")=strPassword


  读写cookie非常简单,上面的代码创建一个cookie并给cookie设置属性:域、过期时间,以及其他一些保存在cookie中的值。这里,strUsename,strPassword是在前面某个地方设置的变量。然后,通过下面的语句在cookie中读取。

  '读取Cookie

  datExpDate=Request.Cookies("MyCookie")

  strDomaln=Request.Cookies("MyCookle").Domain

  strUsername=Request.Cookies("MyCookle")("Username")

  strPassword=Request.Cookies("MyCookie")("Password")

  更详细的信息,可以参考ASP的资料。

  实现

  简单地共享cookie的诀窍是重定向,一般过程为:

  1.一个用户点击siteA.com。

  2.如果用户没有siteA.com的cookie,就把用户重定向到siteB.com。

  3.如果用户有siteB.com的cookie,把用户连同一个特殊的标志(将在下面解释)重定向回siteA.com,否则,只把用户重定向到siteA.com。

  4.在siteA.com创建cookie。

  看起来很简单,仔细分析一下:siteA.com和siteB.com共享相同的用户设置,所以,如果用户有siteB.com的cookie(已经注册),siteA.com能够同样读取cookie、提供cookie所允许的特性。这样,访问siteA.com的用户就如同访问了siteB.com。

  这个检查的环节应该在siteA.com中的文件所包含一个cookies.inc中实现。让我们看一下这段代码:


  l—1

  'SiteA.com"检查cookie

  If Request.Querystring("Checked")<>"True" then

  If not Request.Cookies("SiteA_Cookie").Haskeys then

  '重走向到siteB.com

  Response.Redlrect("http://www.siteB.com/cookie.asp")

  End if

  End if


  如果用户有一个siteA.com的cookie,则不需要做任何事情了;第一个if语句用来消除无限的循环。让我们看一下siteB.com上的cookie.asp文件来获得进一步的理解。

  1—2

  'SiteB.com

  '检查cookie

  If not Request.Cookies("SlteB_Cookle").Haskeys then

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

  '重定向到 siteA.com

  Response.Redirect("http://www.siteA.com/index.asp"&"?checked=True")

  Else

  '获取username

  strUsername=Request.Cookies("SiteB_Cookie")("Username")

  '将用户连同一个特殊的标志返回到siteA.com

  Response.Redlrect("http://www.siteA.com/index.asp"&"?checked=True"&"identrfer="&strUsername)

  End if

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

  如果用户在siteB.com上仍没有cookie,于是,将他送回到siteA.com,并且通过在查询语句中提供一个叫做"checkd"的参数让应用程序知道你已经检查过cookie了。否则,将用户送回到siteB.com,并退出循环。

  然而,如果用户拥有siteB.com的cookie,我们需要将用户送回siteA.com并告诉siteA.com。为此,我们在数据库中附加一个唯一的标志,username。所以,我们扩展siteA.com中的代码。

  l—3

  'SiteA.com
  ...

  ...

  '检查标志

  If Request.Querystring("identifier")<>"" then

  strUsername=Request.Querystring("identifier")

  '记录到数据库

  Response.Cookies("siteA_Cookie").Expires=Date+365

  Response.Cookies("SiteA_Cookie").Domain="siteA.com"

  Response.Cookies("siteA_Cookie")("Username")=strUsername

  End if

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

  最后,我们回到siteA.com。文件的第一部分(l-l)检查是否完成了cookie的检查,由于可以明显地知道已经完成(由语句中的"checked"参数表明),进行到l—3所示的程序的第二部分。如果存在特殊的标志,我们就可以在siteA.com创建cookie。使用这个特殊的标志(在这里是username),我们可以在任何需要的时候查询数据库。然后,设置cookie,显示页面的其他部分。如果没有指定的标志,也没必要担心,只要简单地显示页面的余下部分。

  这样,毫不费力地,siteA.com拥有了和siteB.com一样的cookie。我们可以传输更多的信息而不只是一个标志,并且,将网络流量控制在最小范围内。

  要注意一点,即使用户拥有siteA.com上的cookie,仍需要检查siteB.com。通常来讲,这不是必须的,也会节约时间。但是,一旦用户在siteB.com更改个人信息?这样做,会保持所有信息的同步。

  Cookie环

  要完成这些,我们需要两个文件:一个在原始站点服务器(siteA.com),完成检查;一个在参考服务器(siteB.com),验证用户。如果有一台参考服务器包含有需要的所有用户信息或cookie,就可以增加随意多的原始服务器,所需要做的就是在所有要共享cookie的服务器上增加cookie.inc文件。

  也可以以相反的次序执行,例如,如果siteB.com是原始服务器,而siteA.com包含用户信息。访问过siteA.com却从未访问过siteB.com的用户也可以登录到siteA.com,并且拥有所有的曾经的设置。注意,如果拥有多个参考服务器,这样将会很使人迷惑,并且消耗过多的资源,因为必须将用户重定向到每一台参考服务器。

  理论上讲,可以拥有一个所有站点都共享相同的用户的网络。最可行的方案就是建立共享cookie环。将参考服务器列表存储在一个地方(备份服务器),以便每个参考服务器可以查找并决定重定向用户的下一个站点。记住一定要通过查询字符串的意思跟踪用户是在哪个原始服务器开始。这样信息的传输非常迅速,这个环节变得越来越可行。

  这里还存在一些问题,首先是反应时间。对用户而言,他们最好不知道过程是怎样的。他所需的时间依赖于siteA.com、siteB.com之间的连接,有可能会比较长,在实现cookie环时可能会更长。

  再一个主要问题,就是每一个实现者大都会面对无限的重定向。这有很多原因,例如:用户的测览器不支持cookie。这就需要再设计代码来监测用户浏览器的性能。

  最好,还需要注意安全问题。如果有些黑客发现了其中的诀窍,他可能会得到cookie中的信息。最简单的防范办法就是保护参考服务器,只允许原始服务器访问Cookie.asp文件。

来源:https://www.tulaoshi.com/n/20160219/1627664.html

延伸阅读
标签: 办公软件
EQ?这里指的可不是时下流行的“情商”哦,而是一种WORD域,不过二者之间也有共同点,那就是都需要一定的智商才能用好。好了,开个玩笑而已。许多WORD用户都知道利用EQ域功能可以创建简单的分式、根式等数学公式。但是你知道吗,其它方面EQ域也同样能够派上用场呢! 先来认识一下几个EQ域的简单用法: 1、{ Eq \f(,)}:创建分式,...
/* 豆腐制作 都是精品 http://www.asp888.net 豆腐技术站 如转载 请保留版权信息 */ session 的 管理,我们传统的asp 程序其实是一种 dead 的session 联结,系统其实在我们的客户端书 写了一个Cookie,当我们把我们浏览器的 安全设置中的 Cookie 设置成 Prompt 的时候,当我们访问一个 有Session 的页面的时候,就会出现一个是否允许Cookie 的提示,...
标签: 健康 女性健康
如何跨越30岁健康边界 31:和痘痘说拜拜 人过30,皮脂分泌速度几乎减缓了一半。因此,以往总是油光光的T区不见了,而由于皮脂腺分泌过旺而引起的黑头和青春痘自然也就难以找到生存空间。如果这个年纪再生痤疮,则很可能属于皮肤感染,应该尽快就医。当然,此时皮肤比较20多岁时更容易干燥,因此保湿和润肤是这个年龄女性护肤...
很多网管时常需要向不同向不同网段内的工作站同时提供某种相同的服务,这样一来网管就需要在不同网段的子网中进行”跨越“访问。要实现这中”跨越“访问,其实只要将不同网段的子网连接到具有路由功能的多层网管交换机上就可以实现了,不过这种方法需要耗费大量资金,而且还要对网络进行升级,非常麻烦。其实有几种比较经济的方法,实施起...
标签: word
怎样在Word2013中显示域代码而非域值   第1步,打开Word2013文档窗口,依次单击文件→选项按钮,如图1所示。 图1 单击选项按钮 第2步,打开Word选项对话框,切换到高级选项卡。在显示文档内容区域选中或取消显示域代码而非域值复选框,并单击确定按钮,即可选择显示域代码或显示域值,如图2所示。 图2 选中...

经验教程

603

收藏

18
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部