1. 代码实现
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
resp.setCharacterEncoding("utf-8");
resp.setContentType("text/html");
PrintWriter out = resp.getWriter();
//服务器从客户端获取cookie
Cookie[] cookies = req.getCookies();
//判断cookie是否存在
if (cookies != null){
for (int i = 0; i < cookies.length; i++) {
Cookie cookie = cookies[i];
//获取cookie的名字看是否和第一次登录的时候客户端给他响应的一样
if (cookie.getName().equals("LastLoginTime")){
//获取cookie的值,转换成长整型后以时间格式保存
long LastLoginTime = Long.parseLong(cookie.getValue());
//将时间数据转换成一个对象
Date date = new Date(LastLoginTime);
out.write("你上次登录的时间为:"+date.toLocaleString());
}
}
}else {
out.write("这是你第一次登录!");
}
//服务器给客户端相应一个cookie
Cookie cookie = new Cookie("LastLoginTime",System.currentTimeMillis()+"");
resp.addCookie(cookie);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doGet(req, resp);
}
2.实现过程
1.从请求中拿到cookie信息
2.服务器给客户端响应cookie
Cookie[] cookies = req.getCookies();//服务器从客户端获取cookie
cookie.getName()//获取cookie的key
cookie.getValue() //获取cookie的Value
new Cookie("LastLoginTime",System.currentTimeMillis()+"");//创建一个新的cookie对象
cookie.setMaxAge(24*60*60);//设置cookie的有效期
resp.addCookie(cookie);//给客户端相应一个cookie
cookie一般会保存在本地目录下的appdata文件夹中!
3.cookie的存在限制
一个cookie只能保存一个信息
cookie的大小是有限制的为4KB
一个web站点可以给浏览器发送多个cookie,一个web站点最多存在20个cookie
一个浏览器最多存放300个cookie
4.怎么删除cookie
1.设置cookie的有效期为0 cookie.setMaxAge();
2.不设置有效期,浏览器关闭后cookie自动清空
5.编码解码
//编码
URLEncoder.encode("哈哈哈","utf-8"); //将哈哈哈以utf-8的编码格式传递给服务器
//解码
URLDecoder.decode("","utf-8"); //将对象以utf-8的格式解码传递给客户端