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 来区分的。