java之Cookie详解

                                                 java之Cookie详解

Cookie是由服务器端生成,发送给 User-Agent (一般是浏览器),浏览器会将 Cookie key/value 保存到某个目录下的文本文件内,下次请求同一网站时就发送该Cookie 给服务器(前提是浏览器设置为启用 cookie )。 Cookie 名称和值可以由服务器端开发自己定义,对于 JSP 而言也可以直接写入 JSESSIONID 用于标记一个会话 (session) ,这样服务器可以知道该用户是否合法用户以及是否需要重新登录等,服务器可以设置或读取 Cookies 中包含信息,借此维护用户跟服务器会话中的状态。

Cookie是客户端技术,而 HttpSession 是服务器端技术。

java Cookie 详细介绍 :

1 Cookie 是什么?

一个小信息,由服务器写给浏览器的。由浏览器来保存。

客户端保存的Cookie 信息,可以再次带给服务器。

Cookie类: javax.servlet.http.Cookie

2 Cookie 的属性:

name :必须的

value:必须的

comment:可选的。注释

path : 可选的,如果不设置路径,那么只有设置该 cookie URI 及其子路径可以访问

Cookie 的程序的访问路径是: http://localhost:8080/JavaWeb/servlet/CookieDemo

其中: localhost 就是域名; /JavaWeb/servlet 就是当前 Cookie path
若访问的地址的 URI 包含着 cookie 的路径,即 URI.startWith(cookie 的路径 ), true ,则客户端将该 cookie 带给服务器。
比如浏览器存的 cookie 的路径是 /JavaWeb
现在访问的地址是: http://localhost:8080/JavaWeb/servlet/CookieDemo   则带该 cookie
现在访问的地址是: http://localhost:8080/JavaWeb/CookieDemo   则带该 cookie
若浏览器存的 cookie 的路径是 /JavaWeb/servlet/
访问的地址是: http://localhost:8080/JavaWeb/servlet/CookieDemo    则带该 cookie
访问的地址是: http://localhost:8080/JavaWeb/CookieDemo    则不带该 cookie
如果一个 cookie 的路径设置成了 /JavaWeb ,意味着浏览器访问当前应用下的所有资源时都会带着该cookie 给服务器。

domain:可选的。该 Cookie 所属的网站域名。( apache.org )默认值。

maximum age:可选的。不设置就是会话过程(存在浏览器的内存中)。单位是秒
如果是 0 ,说明要删除。

version:可选的。

3 、如何向客户端写 Cookie

HttpServletResponse对象 .addCookie(javax.servlet.http.Cookie对象 )(就是写了一个响应消息头: Set-Cookie:cookie 的信息)

Servlet规范中的 Cookie API提供了 setMaxAge  setPath setDomain 等方法,可以对Cookie 状态进行控制

特点:一个浏览器针对一个网站最多存20 Cookie ;最多存 300 Cookie ,每个 Cookie 的长度不能超过 4KB (稀缺)。只是规定,但不同的浏览器实现的不同。

1     public void doGet(HttpServletRequest request, HttpServletResponse response)
 2             throws ServletException, IOException {
 3         Cookie cookie=new Cookie("name","Tom");
 4         //设置Maximum Age
 5         cookie.setMaxAge(1000);
 6         //设置cookie路径为当前项目路径
 7         cookie.setPath(request.getContextPath());
 8         //添加cookie
 9         response.addCookie(cookie);
10     }

4 、服务器如何得到客户端传来的 Cookie

Java 中利用 Serlvet 或者 JSP scriptlet 可以向浏览器端写入 Cookie ,同样,利用 Servet 或者 JSP scriptlet 也可以读取到 Cookie 信息

Servlet规范中的 Cookie API 同样存在 getMaxAge  getPath  getDomain等方法,可以获得相应的状态。

不过此处存在一个问题:

读取 Cookie 时,发现除了 Cookie key value 外,其他值获取都为 null

原因很简单:Cookie 从服务器端发送到客户端时,信息是完整的, Cookie 从客户器端发送到服务端时,信息只剩下 key value 了。 ( 因为 Domain 不对的 Cookie Path 不对的 Cookie 、过期的 Cookie ,客户端是不会发送过来的 )

那为什么 Java 中提供了相应的 get 方法呢? 那个方法其实是在生成 Cookie 后,尚未发送到客户端时使用的

服务器端通过HttpServletRequest 对象 .getCookies() 可获取 cookies 数组。

1     public void doGet(HttpServletRequest request, HttpServletResponse response)
 2             throws ServletException, IOException {
 3         PrintWriter out=response.getWriter();
 4         Cookie[] cookies=request.getCookies();
 5         if(cookies!=null){
 6             for(Cookie cookie:cookies){
 7                 String name=cookie.getName();
 8                 String value=cookie.getValue();
 9                 out.write(name+"="+value);
10             }
11         }
12     }

5 、如何区分 Cookie

通过名称不行, 应通过domain+path+name 来区分的。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值