一、显示用户上次访问网站的时间
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //防止中文乱码 response.setContentType("text/html;charset=UTF-8"); PrintWriter out=response.getWriter(); out.write(" 你上次访问的时间是:"); //获取本地的cookie Cookie[] cookies=request.getCookies(); for(int i=0;cookies!=null && i<cookies.length;i++){ if(("lastAccessTime").equals(cookies[i].getName())){ //字符串的日期转换为long,在通过Date转化为日期,通过toLocalString 来输出 Long cookieValue=Long.parseLong(cookies[i].getValue()); Date date=new Date(cookieValue); out.write(" 你上次访问的时间是:"); out.write(date.toLocaleString()); } } //把cookie写回本地去 Cookie cookie=new Cookie("lastAccessTime",System.currentTimeMillis()+""); cookie.setMaxAge(1*24*3600); cookie.setPath("/day08"); response.addCookie(cookie); }
二、清除Cookie
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { Cookie cookie=new Cookie("lastAccessTime",System.currentTimeMillis()+""); cookie.setMaxAge(0); cookie.setPath("/day08"); response.addCookie(cookie); }
三、cookie的一些细节
1、一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)
2、 一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。
3、浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
4、如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。 若希望浏览器将该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。
5、注意,删除cookie时,path必须一致,否则不会删除