cookie是一种缓存技术
不同的浏览器保存和查看cookie的方式是不同的
对关于cookie的创建,随着会话会传给浏览器
public class LoginServlet extends HttpServlet {
private int counter;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
PrintWriter out;
Cookie cookie = new Cookie("name", "wenhao");
Cookie cookie2 = new Cookie("age", "13");
response.addCookie(cookie);
response.addCookie(cookie2);
}
}
这里我们设置的访问LoginServlet路径为:http://localhost:8080/19-cookie/ooo/xxx/LoginServlet
以下是访问该servlet之后返回的信息,可以看到设置的cookie已经传同response传回给了浏览器,浏览器接收的信息如下图
当客户端访问同类请求时,cookie会被提交:什么是同类请求,就是资源路径名相同,如本例就是http://localhost:8080/19-cookie/ooo/xxx
当我们通过浏览器提交http://localhost:8080/19-cookie/ooo/xxx/sdsda,随意提交一个资源路径,虽然没有该资源,但是cookie会被提交,因为cookie是存在本地客户端的,可看到客户端的提交信息如下
指定绑定路径
以上的例子都是提交同类请求(即跟发送该cookie的servlet相同资源路径)后,浏览器会将cookie提交至服务器。
也可以指定cooke提交的路径
例如我想在,http://localhost:8080/19-cookie/ooo 为资源路径时提交cookie1
在http://localhost:8080/19-cookie/ccc/sss 为资源路径时提交cookie2
具体实现代码如下
以下代码是在LoginServlet
Cookie cookie = new Cookie("name", "wenhao");
Cookie cookie2 = new Cookie("age", "13");
//重点注意,绑定路径时要加上web应用的名称,这里就在本应用下
cookie.setPath(request.getContextPath()+"/ooo");
cookie2.setPath(request.getContextPath()+"/ccc/sss");
response.addCookie(cookie);
response.addCookie(cookie2);
当访问LoginServlet后返回的信息如下,可以看到cookie后面会带上绑定的路径了
当我们以/19-cookie/ooo为资源路径提交时,或者直接访问这个路径,或者路径中包含该路径如(/19-cookie/ooo/sss/sdsd/aas)提交请求里就会包含cookie如下图
以/19-cookie/ccc/sss为资源路径,或者直接访问这个路径,或者路径中包含该路径如(/19-cookie/ccc/sss/sdsd/aas)提交时,提交请求里会包含如下图的cookie,因为前面时绑定好了的
以上的都未设置cookie保留的时间,cookie只保留在浏览器的缓存里,没有写入客户端的硬盘中
通过cookie的方法cookie.setMaxAge(int expiry);将cookie写入客户端硬盘内部,即使关闭了浏览器后面还可以访问
expiry 为正数时,代表保存 expiry 秒
为0时,标识cookie一旦生成,马上无效
为负数时,与不设置相同,放在客户端的缓存里
服务器解析cookie
服务器解析cookie,生成cookie的目的是拿来让浏览器提交给服务器解析的
通过requset获取cookie组成的数组
Cookie[] cookies = request.getCookies();
for(Cookie c:cookies) {
System.out.println("cookie name = "+c.getName());
System.out.println("cookie value ="+c.getValue());
}
cookie的禁用
有些浏览器禁用cookie后无法使用