首页 > 代码库 > JavaWeb基础—会话管理之Cookie

JavaWeb基础—会话管理之Cookie

一、什么是会话

  打开浏览器,浏览各种资源,点击各种超链接,直至关闭浏览器,整个过程称为会话

二、会话管理的两种技术

  1.Cookie

    基于客户端。以cookie的形式写给用户各自的浏览器。当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去。

  2.Session

    基于服务端。session类似于客户端在服务器端的账户。使用Map存放。服务器在运行时可以为每一个用户的浏览器创建一个其独享的session对象。

三、Cookie的用途 

  Cookie的用途:
      服务器用来跟踪客户端状态
      保存购物车等
      显示上次登录的名称

  (常用为保存购物车,自动登陆)

四、Cookie常用API

  在 javax.servlet.http.Cookie这个包中,可以查询到几个常见的API

    Cookie(String name, String value) : Cookie的构造器

    get/setMaxAge(int age) : 操作cookie的最大存活时间(cookie的有效期),设置了有效期后关闭浏览器会把cookie保存到硬盘上。不设置则关闭了浏览器会话就结束了,cookie也就不存在了。<0则在内存中的寿命以秒为单位。>0为设置一个过期时间,=0就是杀死了。

    getName() : 得到cookie的名字

    get/setValue(String newValue) : 操作cookie的值

    get/setPath() : 操作cookie的有效路径,比如把cookie的有效路径设置为"/xdp",那么浏览器访问"xdp"目录下的web资源时,都会带上cookie

五、javaWeb中操作cookie

便捷方式(精通):response.addCookie():服务器向客户端(浏览器)保存cookie  服务端送出(add)
         request.getCookies():加了s,返回的是浏览器归还的cookies(数组)  客户端拿(get)

         例如得到最后一次登陆时间: 

   PrintWriter out = response.getWriter();
        //获取浏览器访问访问服务器时传递过来的cookie数组
         Cookie[] cookies = request.getCookies();
        //如果用户是第一次访问,那么得到的cookies将是null
         if (cookies!=null) {
             out.write("您上次访问的时间是:");
             for (int i = 0; i < cookies.length; i++) {
                Cookie cookie = cookies[i];
                 if (cookie.getName().equals("lastAccessTime")) {
                    Long lastAccessTime =Long.parseLong(cookie.getValue());
                     Date date = new Date(lastAccessTime);
                     out.write(date.toLocaleString());
                }
             }
         }else {
             out.write("这是您第一次访问本站!");
        }
         
         //用户访问过之后重新设置用户的访问时间,存储到cookie中,然后发送到客户端浏览器
         Cookie cookie = new Cookie("lastAccessTime", System.currentTimeMillis()+"");//创建一个cookie,cookie的名字是lastAccessTime
        //将cookie对象添加到response对象中,这样服务器在输出response对象中的内容时就会把cookie也输出到客户端浏览器
         response.addCookie(cookie);
    }

JavaWeb基础—会话管理之Cookie