通过cookie技术实现记录用户的上一次访问时间并显示出来

package com.javaweb.servlet;
/*案例:网站为了提高用户的感受,将用户的上一次的访问时间
 * 显示给用户使用cookie来实现
 * 浏览器关闭之后再次打开去访问,发现又变成第一次访问了
 * 注意:默认情况下。一个cookie的有效期是浏览器进程,那么在浏览器关闭之后浏览器进程就没有了
 * 那么相应的cookie信息也就没有了,如何实现在浏览器关闭之后,再次打开仍然可以显示上次
 * 访问时间呢?
 * 可以自己手动的去设置cookie的有效期就好了,设置cookie的有效期之后,只要是有效期内
 * ,那么cookie就会一直保留在浏览器的缓存中,以文件的形式存在。
 * 第二:给cookie设置有效路径,那么就表示当再次使用浏览器去访问某个目标资源的时候,如果要
 * 访问的目标的路径与cookie所包含的有效路径不匹配,那么cookie不会在访问的时候带给服务器,
 * 1:一般情况下设置成什么样的路径较多?
 * setPath(“/”)写成/并不是最好的但是确实使用最多的
 * 2:一个cookie持久化保存到硬盘上的时候实际上还是可以通知浏览器删除这个cookie的,就是将
 * setMaxAge设置为0,设置为0就是表示不保存cookie信息了,但是特别注意,删除cookie的时候
 * 这个cookie名称和有效路径必须一致,否则不会删除。
 * */
import java.io.IOException;
import java.util.Date;


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


/**
 * Servlet implementation class ServletAfterTime
 */
@WebServlet("/servletAfterTime")
public class ServletAfterTime extends HttpServlet {
private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public ServletAfterTime() {
        super();
        // TODO Auto-generated constructor stub
    }


/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub

doPost(request, response);
}


/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//获取用户请求的时候封装在request中的cookie信息
Cookie[] cookies=request.getCookies();
//遍历这个cookie的数组,找到目标cookie对象,每一个cookie会有一个唯一的名字用来标识该cookie对象
Cookie tagetCookie=findeTagetCookie(cookies, "lastvisit");
response.setContentType("text/html;charset=utf-8");
if (tagetCookie==null) {
//说明没有带cookie目标过来,那么就默认为你是第一次访问
response.getWriter().print("哥们,你是第一次访问本网站。。。。");
}else {
//说明访问过
String value= tagetCookie.getValue();
long time= Long.parseLong(value);
response.getWriter().print("哥们,您上一次访问的时间是:"+new Date(time).toLocaleString());

}
//当前的时间写回去
Cookie cookie=new Cookie("lastvisit", System.currentTimeMillis()+"");
cookie.setPath("/");
//设置有效路径,/表示当前主机名localhost,表示只有访问localhost主机下的某个资源的时候才会带过去
cookie.setMaxAge(60*60*24*7);//以当前时间开始,保存一个星期;以秒为单位
response.addCookie(cookie);//将cookie写给用户的浏览器


}
private Cookie findeTagetCookie(Cookie[] cookies,String name){
if (cookies==null) {
//说明没有带任何数据的cookie过来,就直接返回null
return null;
}
//如果走到这里,则说明带了cookie过来,那么就遍历这个数组,找到目标的cookie对象
for (Cookie cookie : cookies) {
if (cookie.getName().equals(name)) {
//说明当前的cookie就是目标cookie,那么就会返回cookie对象
return cookie;
}

}
return null;
}

}

运行结果:

(因为浏览过一次,所以显示的是上一次的浏览时间,如果是第一次就会显示“哥们,你是第一次访问本网站。。。。”)


Cookie技术是一种在客户端存储小量数据的技术,常用于记录用户的登录状态、个性化设置等信息。要实现显示用户上次访问时间的功能,可以按照以下步骤操作: 1. **服务器端**: - 当用户访问网站成功登录后,服务器端创建一个包含用户ID和访问时间的字典(JSON格式),将这个字典序列化为一个字符串。 - 将这个字符串作为值(通常设置一个较长的过期时间,如一个月),通过`Set-Cookie`头发送到浏览器,键名为表示用户信息的标识符,比如`lastVisitTimeUser`。 ```http Set-Cookie: lastVisitTimeUser=1689034560; expires=Sat, 17-Jan-2024 00:00:00 GMT; path=/; ``` 2. **浏览器端**: - 浏览器收到`Set-Cookie`响应后,会在本地存储(`cookies`文件夹)保存这个信息。 - 下次用户再次访问网站时,浏览器会自动携带这个`Cookie`。 3. **客户端JavaScript**: - 使用JavaScript的`document.cookie`属性读取这个cookie解析出用户最后一次访问时间戳(例如,1689034560是一个Unix时间戳)。 - 转换这个时间戳为可读的日期格式(如`new Date(1689034560)`)。 4. **显示时间**: - 将处理过的日期展示给用户,如"您上次访问时间为2023年1月1日"。 需要注意的是,为了保护用户隐私,现代浏览器对第三方 Cookie 的管理更为严格,可能需要用户明确同意或网站通过其他安全机制(如服务端存储)来实现这种功能。另外,频繁使用 cookies 可能会影响用户体验,因此要谨慎设计使用场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值