java中cookie设置上次登录时间

  1. import java.io.IOException;  
  2. import java.io.PrintWriter;  
  3. import java.text.DateFormat;  
  4. import java.text.SimpleDateFormat;  
  5. import java.util.Date;  
  6.   
  7. import javax.servlet.ServletException;  
  8. import javax.servlet.http.Cookie;  
  9. import javax.servlet.http.HttpServlet;  
  10. import javax.servlet.http.HttpServletRequest;  
  11. import javax.servlet.http.HttpServletResponse;  
  12.   
  13. //代表网站首页  
  14. //Cookie技术显示用户上次访问网站的时间  
  15. public class CookieDemo1 extends HttpServlet {  
  16.   
  17.     public void doGet(HttpServletRequest request, HttpServletResponse response)  
  18.             throws ServletException, IOException {  
  19.         response.setCharacterEncoding("UTF-8");  
  20.         response.setHeader("Content-type""text/html;charset=UTF-8");  
  21.         PrintWriter out = response.getWriter();  
  22.         out.print("<a href='/day07/servlet/CookieDemo2'>清除上次访问时间</a><br>");  
  23.         out.print("您上次访问的时间是:");  
  24.         // 拿到请求头中所有的cookie  
  25.         Cookie cookies[] = request.getCookies();  
  26.         // 遍历cookies找到lastAccessTime这个cookie  
  27.         for (int i = 0; cookies != null && i < cookies.length; i++) {  
  28.             if (cookies[i].getName().equals("lastAccessTime")) {  
  29.                 // 得到最后访问时间的毫秒数  
  30.                 long cookieValue = Long.parseLong(cookies[i].getValue());  
  31.                 // 将最后访问时间变成一个日期类型  
  32.                 Date date = new Date(cookieValue);  
  33.                 // 格式化这个日期  
  34.                 DateFormat df = new SimpleDateFormat("yyyy-MM-WW kk:mm:ss");  
  35.                 String lastAccessTime = df.format(date);  
  36.   
  37.                 out.print(lastAccessTime);  
  38.             }  
  39.         }  
  40.         // 将最新的访问时间设置回去  
  41.         Cookie cookie = new Cookie("lastAccessTime", System.currentTimeMillis()  
  42.                 + "");  
  43.         // 设置有效期为一个月  
  44.         cookie.setMaxAge(1 * 3600 * 24 * 30);  
  45.         // 设置有效访问路径为/day07这个项目下的所有资源  
  46.         cookie.setPath("/ghj");  
  47.         // 在response中增加一个cookie,服务器会自动增加Set-Cookie头字段  
  48.         response.addCookie(cookie);  
  49.     }  
  50.   
  51.     public void doPost(HttpServletRequest request, HttpServletResponse response)  
  52.             throws ServletException, IOException {  
  53.         doGet(request, response);  
  54.     }  
  55.   
  56. }  
[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. import java.io.IOException;  
  2.   
  3. import javax.servlet.ServletException;  
  4. import javax.servlet.http.Cookie;  
  5. import javax.servlet.http.HttpServlet;  
  6. import javax.servlet.http.HttpServletRequest;  
  7. import javax.servlet.http.HttpServletResponse;  
  8. //删除浏览器中的cookie  
  9. public class CookieDemo2 extends HttpServlet {  
  10.   
  11.     public void doGet(HttpServletRequest request, HttpServletResponse response)  
  12.             throws ServletException, IOException {  
  13.         test1(response);  
  14.   
  15.         test2(request, response);  
  16.     }  
  17.   
  18.     // 自己实验的方法,拿到了原有的cookie想要删除还是要先设置下Path,否则Path还是会在这个servlet的目录下  
  19.     // 拿到了原有的cookie,如果只修改setMaxAge为0还是不行的!  
  20.     private void test2(HttpServletRequest request, HttpServletResponse response) {  
  21.         // 拿到请求头中所有的cookie  
  22.         Cookie cookies[] = request.getCookies();  
  23.         // 遍历cookies找到lastAccessTime这个cookie  
  24.         for (int i = 0; cookies != null && i < cookies.length; i++) {  
  25.             if (cookies[i].getName().equals("lastAccessTime")) {  
  26.                 Cookie cookie = cookies[i];  
  27.                 cookie.setMaxAge(0);  
  28.                 cookie.setPath("/ghj");  
  29.                 response.addCookie(cookie);  
  30.             }  
  31.         }  
  32.     }  
  33.   
  34.     // 开发中的方法  
  35.     private void test1(HttpServletResponse response) {  
  36.         Cookie cookie = new Cookie("lastAccessTime""");  
  37.         // 设置为0表示让浏览器删除这个cookie  
  38.         cookie.setMaxAge(0);  
  39.         // 删除cookie的时候Path必须一致,因为同一个cookie,Path肯定一致  
  40.         cookie.setPath("/ghj");  
  41.         response.addCookie(cookie);  
  42.     }  
  43.   
  44.     public void doPost(HttpServletRequest request, HttpServletResponse response)  
  45.             throws ServletException, IOException {  
  46.         doGet(request, response);  
  47.     }  
  48.   
  49. }  

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必须一致,否则不会删除

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值