Cookies使用

本文介绍了如何使用Cookie来提升Web应用的功能性和用户体验,包括定制化界面、存储用户偏好等,并提供了具体的实现示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 
实际上,在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值当作一个变量看待,执行下面的代码,将取回名字为KensCookiecookie值,并存入变量MyVar
MyVar=Request.Cookies("KensCookie")

  执行下面的代码,将判断名字为KensCookiecookie值是否为“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
% >
  好,下面开始从头讨论上面的代码。

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


< %@ 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的扩展性是无穷的,这篇文章仅仅是抛砖引玉。
 
 
### 京东 Cookies使用方法与实现细节 Cookies 是一种用于保存客户端状态的技术,在 Web 应用程序中广泛应用于会话管理、个性化设置以及身份认证等功能。以下是关于京东 Cookies 的具体使用方法和实现细节: #### 1. 创建并绑定数据到 Cookie 对象 在 JavaWeb 中,可以通过 `new Cookie(String name, String value)` 方法创建一个 Cookie 对象,并将其绑定到指定的数据。例如: ```java // 创建名为 "username" 值为 "JohnDoe" 的 Cookie Cookie userCookie = new Cookie("username", "JohnDoe"); ``` 此操作定义了一个新的 Cookie 并为其设置了名称和值[^1]。 #### 2. 将 Cookie 添加到 HTTP 响应头 为了使浏览器能够接收并存储这个 Cookie,服务器需要通过响应头将它发送给客户端。这一步通常由以下代码完成: ```java // 向响应中添加 Cookie response.addCookie(userCookie); ``` 当浏览器接收到带有 Set-Cookie 头部字段的响应时,就会自动保存对应的 Cookie 数据[^1]。 #### 3. 获取已有的 Cookie 数组 如果想读取之前已经存在的 Cookie,则可以在请求到达服务端之后调用 `request.getCookies()` 来获得所有的 Cookie 集合。下面是一个简单的例子展示如何遍历这些 Cookies 找寻特定的一个: ```java // 获取所有 Cookies Cookie[] cookies = request.getCookies(); if (cookies != null) { for (Cookie cookie : cookies) { if ("username".equals(cookie.getName())) { System.out.println("Username from Cookie: " + cookie.getValue()); } } } ``` 这段代码展示了怎样检索出名字叫作 “username” 的那个 Cookie 及其关联的内容。 #### 4. SSO 登录中的应用实例 —— 京东 Passport 流程解析 以京东为例,它的单点登录(SSO)过程充分体现了 Cookies 在跨域场景下的重要角色。整个流程大致分为以下几个阶段: - **初始访问状态** 用户首次打开网站页面时可能还没有任何有效的 session 或者 authentication token 存在于本地 storage 当中;此时仅存在一些基础性的 tracking 类型的小文件比如广告追踪用途等。 - **触发登录动作后的处理逻辑** 当用户决定执行登录行为后会被重定向至专门负责账号验证的服务站点 passport.360buy.com 。在此期间可能会生成初步的身份标识符存入临时性质的 Cookie (如 alc),供后续环节校验合法性之需[^2]。 - **正式提交表单项进行身份确认** 完成必要的输入框填写工作以后按下按钮递交资料过去审核。假如一切顺利的话那么将会得到认可结果连同新产生的持久化标志一起反馈回来——即所谓的 sso ticket 形式的 long-lived credential ,形式上表现为另一个独立命名空间内的新型号标签 ceshi3.com。 - **最后一步完善整体体验链条构建** 成功返回主页之后并非结束而是刚刚开始因为还需要进一步巩固先前建立起来的信任关系所以紧接着安排了一次额外的秘密握手活动也就是所谓 hello 请求旨在再次核实当前在线个体确实拥有预期权限从而激活隐藏功能模块或者解锁高级权益等等[^2]。 以上就是围绕着京东平台所展开的一系列有关于 Cookies 运用方面的介绍说明希望能够对你有所帮助理解它们背后的工作原理及其实际应用场景价值所在之处!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值