cookie

Cookie

什么是Cookie

1、Cookie是一种在客户端保持HTTP状态信息的技术,它好比商场发放的优惠卡。

2、Cookie是在浏览器访问WEB服务器的某个资源时,由WEB服务器在HTTP响应消息头中附带传送给浏览器的一片数据,WEB服务器传送给各个客户端浏览器的数据是可以各不相同的。

3、  一旦WEB浏览器保存了某个Cookie,那么它在以后每次访问该WEB服务器时,都应在HTTP请求头中将这个Cookie回传给WEB服务器。

4、  WEB服务器通过在HTTP响应消息中增加Set-Cookie响应头字段将Cookie信息发送给浏览器,浏览器则通过在HTTP请求消息中增加Cookie请求头字段将Cookie回传给WEB服务器。

5、  一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。

6、  一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。

7、  浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。  

Set-Cookie2响应头字段

1、  Set-Cookie2头字段用于指定WEB服务器向客户端传送的Cookie内容,但是按照Netscape规范实现Cookie功能的WEB服务器,使用的是Set-Cookie头字段,两者的语法和作用类似。

2、  Set-Cookie2头字段中设置的cookie内容是具有一定格式的字符串,它必须以Cookie的名称和设置值开头,格式为“名称=值”,后面可以加上0个或多个以分号(;)和空格分隔的其它可选属性,属性格式一般为“属性名=值”。

      举例:Set-Cookie2:user=it315; Version=1; Path=/

1、  除了“名称=值”对必须位于最前面外,其它的可选属性的先后顺序可以任意。

2、  Cookie的名称只能由普通的英文ASCII字符组成,浏览器不用关心和理解Cookie的值部分的意义和格式,只要WEB服务器能理解值部分的意义就行。

3、  大多数现有的WEB服务器都是采用某种编码方式将值部分的内容编码成可打印的ASCII字符,RFC 2965规范中没有明确限定编码方式。

 Cookie请求头字段

1、  浏览器使用Cookie请求头字段将Cookie信息回送给WEB服务器。

2、  多个Cookie信息通过一个Cookie请求头字段回送给WEB服务器。 

3、  浏览器根据下面的几个规则决定是否发送某个Cookie信息:

(1)、请求的主机名是否与某个存储的Cookie的Domain属性匹配;

(2)、请求的端口号是否在该Cookie的Port属性列表中;

(3)、请求的资源路径是否在该Cookie的Path属性指定的目录及子目录中;

(4)、该Cookie的有效期是否已过。

4、  Cookie请求头字段中的每个Cookie之间用逗号(,)或分号(;)分隔。

5、  在Cookie请求头字段中除了必须有“名称=值”的设置外,还可以有Version、Path、Domain、Port等几个属性。

6、  在Version、Path、Domain、Port等属性名之前,都要增加一个“$”字符作为前缀。

7、  Version属性只能出现一次,且要位于Cookie请求头字段设置值的最前面,如果需要设置某个Cookie信息的 Path、Domain、Port等属性,它们必须位于该Cookie信息的“名称=值”设置之后。

 

8、  Path属性指向子目录的Cookie排在Path属性指向父目录的Cookie之前。   

举例:Cookie: $Version=1; Course=Java;$Path=/it315/lesson; Course=vc; $Path=/it315

 在Servlet程序中使用Cookie

1、        ServletAPI中提供了一个javax.servlet.http.Cookie类来封装Cookie信息,它包含有生成Cookie信息和提取Cookie信息的各个属性的方法。

2、        Cookie类的方法:

构造方法: public Cookie(java.lang.Stringname,java.lang.String value)

getName方法

setValue与getValue方法

setMaxAge与getMaxAge方法

setPath与getPath方法

setDomain与getDomain方法

setVersion与getVersion方法

setComment与getComment方法

setSecure与getSecure方法

HttpServletResponse接口中定义了一个addCookie方法,它用于在发送给浏览器的HTTP响应消息中增加一个Set-Cookie响应头字段。

HttpServletRequest接口中定义了一个getCookies方法,它用于从HTTP请求消息的Cookie请求头字段中读取所有的Cookie项。

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值