javaweb之Cookie显示上次登录时间和清除Cookie、Cookie的细节

import java.io.IOException;
import java.io.PrintWriter;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;

import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

//代表网站首页
//Cookie技术显示用户上次访问网站的时间
public class CookieDemo1 extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setCharacterEncoding("UTF-8");
		response.setHeader("Content-type", "text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();
		out.print("<a href='/day07/servlet/CookieDemo2'>清除上次访问时间</a><br>");
		out.print("您上次访问的时间是:");
		// 拿到请求头中所有的cookie
		Cookie cookies[] = request.getCookies();
		// 遍历cookies找到lastAccessTime这个cookie
		for (int i = 0; cookies != null && i < cookies.length; i++) {
			if (cookies[i].getName().equals("lastAccessTime")) {
				// 得到最后访问时间的毫秒数
				long cookieValue = Long.parseLong(cookies[i].getValue());
				// 将最后访问时间变成一个日期类型
				Date date = new Date(cookieValue);
				// 格式化这个日期
				DateFormat df = new SimpleDateFormat("yyyy-MM-WW kk:mm:ss");
				String lastAccessTime = df.format(date);

				out.print(lastAccessTime);
			}
		}
		// 将最新的访问时间设置回去
		Cookie cookie = new Cookie("lastAccessTime", System.currentTimeMillis()
				+ "");
		// 设置有效期为一个月
		cookie.setMaxAge(1 * 3600 * 24 * 30);
		// 设置有效访问路径为/day07这个项目下的所有资源
		cookie.setPath("/day07");
		// 在response中增加一个cookie,服务器会自动增加Set-Cookie头字段
		response.addCookie(cookie);
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}
import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//删除浏览器中的cookie
public class CookieDemo2 extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		test1(response);

		test2(request, response);
	}

	// 自己实验的方法,拿到了原有的cookie想要删除还是要先设置下Path,否则Path还是会在这个servlet的目录下
	// 拿到了原有的cookie,如果只修改setMaxAge为0还是不行的!
	private void test2(HttpServletRequest request, HttpServletResponse response) {
		// 拿到请求头中所有的cookie
		Cookie cookies[] = request.getCookies();
		// 遍历cookies找到lastAccessTime这个cookie
		for (int i = 0; cookies != null && i < cookies.length; i++) {
			if (cookies[i].getName().equals("lastAccessTime")) {
				Cookie cookie = cookies[i];
				cookie.setMaxAge(0);
				cookie.setPath("/day07");
				response.addCookie(cookie);
			}
		}
	}

	// 开发中的方法
	private void test1(HttpServletResponse response) {
		Cookie cookie = new Cookie("lastAccessTime", "");
		// 设置为0表示让浏览器删除这个cookie
		cookie.setMaxAge(0);
		// 删除cookie的时候Path必须一致,因为同一个cookie,Path肯定一致
		cookie.setPath("/day07");
		response.addCookie(cookie);
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

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


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值