Cookie知识讲解
Cookie技术
今天老师在课上为我们讲解了Cookie技术,其中老师主要给我们讲了关于Cookie的一下几个知识:
1、 什么是Cookie,在这主要分为下面几点来讲解的:
(1)Cookie是一种在客户端保持http状态信息的技术。
(2)Cookie是在浏览器访问WEB服务器的某个资源时,由WEB服务器在HTTP响应消息头中附带传送给浏览器的一片数据,WEB服务器传送给各个客户端浏览器的数据是可以各不相同的。
(3)一旦WEB浏览器保存了某个Cookie,那么它在以后访问该WEB服务器时,都应该在http请求头中将这个Cookie回传给WEB服务器
(4)一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)
(5)一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器可以存储多个WEB站点提供的Cookie。
(6)浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
2、 Cookie的传送过程,在讲解此知识点是老师用了下面的示意图:
3、 在上面讲解完之后我们已经对Cookie已经了有一个初步的了解,下面我们就先讲一下在servlet程序中使用Cookie,其中主要讲解了一下几点:
(1)ServletAPI中提供了一个javax.servlet.http.Cookie信息,它包含有生成Cookie信息和提取Cookie信息的各个属性的方法。
(2)Cookie类的方法:
构造方法: publicCookie(java.lang.String name,java.lang.String value)
getName方法
setValue与getValue方法
setMaxAge与getMaxAge方法
setPath与getPath方法
setDomain与getDomain方法
setVersion与getVersion方法
setComment与getComment方法
setSecure与getSecure方法
(3)HttpServletResponse接口中定义了一个addCookie方法,它用于在发送给浏览器的http响应消息中增加一个Set—Cookie响应头字段。
(4)HttpServletRequest接口中定义了一个getCookies方法,它用于从http请求消息的Cookie请求头字段中读取所有的Cookie项。
4、在Servlet程序中使用Cookie的时候我们会需要用到Set-Cookie响应头字段和Cookie请求头字段,所以下面我们就讲解一下:
(1)Set-Cookie响应头字段:
Set-Cookie头字段用于指定WEB服务器向客户端传送的Cookie内容,但是按照Netscape规范实现Cookie功能的WEB服务器,使用的是Set-Cookie头字段,两者的语法和作用类似。
Set-Cookie头字段中设置的cookie内容是具有一定格式的字符串,它必须以Cookie的名称和设置值开头,格式为“名称=值”,后面可以加上0个或多个以分号(;)和空格分隔的其他可选属性,属性格式一般为:“属性值”。
例如:Set-Cookie2: user=it315;Version=1; Path=/
除了“名称=值”对必须位于最前面外,其它的可选属性的先后顺序可以任意。
Cookie的名称只能由普通的英文ASCII字符组成,浏览器不用关心和理解Cookie的值部分的意义和格式,只要WEB服务器能理解值部分的意义就行。
大多数现有的WEB服务器都是采用某种编码方式将值部分的 内容编码成可打印的ASCII字符,RFC2965规范中没有明确限定编码方式。
Set-Cookie头字段中的属性:Comment=value,Discard,Domain=value。
例如:Set-Cookie2: user=it315; Version=1; Path=/; Domain=.it315.org。
Max-Age-value,Port[=”portlist”],Path=value,Secure,Version=value.
(2)、Cookie请求头字段:
浏览器使用Cookie请求头字段将Cookie信息回送给WEB服务器。
多个Cookie信息通过一个Cookie请求头字段回送给WEB服务器
浏览器根据下面的几个规则决定是否发送某个Cookie信息:
请求的主机名是否与某个存储的Cookie的Domain属性匹配;
请求的端口号是否在该Cookie的Port属性列表中;
请求的资源路径是否在该Cookie的Path属性指定的目录及子目录中;
该Cookie的有效期是否已过。
Cookie请求头字段中的每个Cookie之间用逗号(,)或分号(;)分隔。
在Cookie请求头字段中除了必须有“名称=值”的设置外,还可以有Version、Path、Domain、Port等几个属性。
在Version、Path、Domain、Port等属性名之前,都要增加一个“$”字符作为前缀。
Version属性只能出现一次,且要位于Cookie请求头字段设置值的最前面,如果需要设置某个Cookie信息的 Path、Domain、Port等属性,它们必须位于该Cookie信息的“名称=值”设置之后。
Path属性指向子目录的Cookie排在Path属性指向父目录的Cookie之前。
举例:Cookie:$Version=1; Course=Java; $Path=/it315/lesson; Course=vc; $Path=/it315
5、上面我们讲述了Cookie的一些基本的知识,最后我们在讲述关于Cookie的综合实例中的功能说明:
程序包含两个Servlet组件:CookieServlet1.java和CookieServlet2.java。
CookieServlet1中产生四个名称分别为name、nickname、email、phone的Cookie信息。name和nickname这两个Cookie的值是通过请求参数来设置的,并且nickname这个Cookie保持有效的时间为1年,email和phone这两个cookie的值是在程序中硬编码指定的。
在产生Cookie信息之后,CookieServlet1接着从请求消息中查找名称为nickname的Cookie信息,并根据返回结果打印出相应的问候语,CookieServlet1还打印出请求消息中的Cookie头字段的值。
CookieServlet2首先创建三个名称分别为email、phone、sign的Cookie信息,并将phone这个Cookie保持有效的时间设置为了0秒,然后打印出请求消息中的Cookie头字段的值和每个Cookie的名称。
CookieServlet2中的email和phone这两个Cookie曾在CookieServlet1程序中设置过,在CookieServlet2程序再次进行设置,是为了便于查看设置同名Cookie的效果和了解如何删除Cookie。
最后是我们的实例代码:
CookieckName = new Cookie("name",name);
CookieckNickname = new Cookie("nickname",nickname);
ckNickname.setMaxAge(365*24*3600);
CookieckEmail = new Cookie("email","test1@it315.org");
CookieckPhone = new Cookie("phone","1111111");
response.addCookie(ckName);
response.addCookie(ckNickname);
response.addCookie(ckEmail);
response.addCookie(ckPhone);
StringlastNickname = null;
Cookie[] cks = request.getCookies();
for(inti=0; cks!=null && i<cks.length; i++)
{
if("nickname".equals(cks[i].getName()))
{
lastNickname = cks[i].getValue();
break;
}
}
if(lastNickname!= null)
{
out.println("欢迎您," + lastNickname );
}
摘自:雪狼小记
补充:Web开发 , 其他 ,