用Cookie记录上次的访问时间

# 用Cookie记录上次的访问时间

/**

  • 思路:
  • 先判断是否是第一次进入该页面
  • 如果是,则响应: 欢迎您首次访问
  • 如果不是,则响应: 上次的访问时间
  • 具体步骤:
  • 1.遍历所有的Cookie,看有没有该Cookie(事先设定一个Cookie)
  • 2 如果有,则说明不是第一次登录
  • 2.1 获取上次登录时的Cookie值,响应: 上次的访问时间
  • 2.2记录本次的登录时间
  • 3.如果没有,说明是第一次登录,记录当下的时间,存入Cookie
  • 3.1响应: 欢迎您首次访问

*/

@WebServlet("/cookieTest")
public class CookieTest extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //设置请求和响应编码
        request.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");
        //创建一个布尔值
        boolean flag = false;
        //获取所有cookie
        Cookie[] cookies = request.getCookies();
        if (cookies != null && cookies.length > 0) {
            //遍历cookie
            for (Cookie cookie : cookies) {
                //判断是否是第一次进入
                if ("lastTime".equals(cookie.getName())) {
                    flag = true;
                    //说明不是第一次进入
                    //获取上次的访问时间
                    String value = cookie.getValue();
                    //URL解码
                    value = URLDecoder.decode(value, "utf-8");
                    //响应页面
                    response.getWriter().write("<h1>"+"你上次的访问时间为:" + value+"</h1>");
                    //记录本次的访问时间
                    Date date = new Date();
                    SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH时mm分ss秒");
                    String format = sdf.format(date);
                    //URL编码
                    format = URLEncoder.encode(format, "utf-8");
                    //用cookie记录
                    cookie.setValue(format);
                    //设置时间为1个月
                    cookie.setMaxAge(60 * 60 * 24 * 30);
                    //发送cookie
                    response.addCookie(cookie);
                }
            }

        }

        if (cookies == null || cookies.length == 0 || flag == false) {
            //说明是第一次访问
            //记录本次的访问时间
            Date date = new Date();
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH时mm分ss秒");
            String format = sdf.format(date);
            //URL编码
            format = URLEncoder.encode(format, "utf-8");
            //创建cookie
            Cookie cookie = new Cookie("lastTime", format);
            //用cookie记录
            cookie.setValue(format);
            //设置时间为1个月
            cookie.setMaxAge(60 * 60 * 24 * 30);
            //发送cookie
            response.addCookie(cookie);
            //响应页面
            response.getWriter().write("欢迎您首次访问");
        }
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您解答这个问题。 在JSP页面中,可以通过Cookie对象来记录和获取上次访问时间。 下面是一个示例代码: ``` <% // 获取当前时间 Date currentDate = new Date(); // 获取上次访问时间Cookie Cookie lastVisitCookie = null; Cookie[] cookies = request.getCookies(); if (cookies != null) { for (Cookie cookie : cookies) { if (cookie.getName().equals("lastVisit")) { lastVisitCookie = cookie; break; } } } // 设置新的Cookie String lastVisitTime = "首次访问"; if (lastVisitCookie != null) { lastVisitTime = lastVisitCookie.getValue(); } Cookie newVisitCookie = new Cookie("lastVisit", currentDate.toString()); newVisitCookie.setMaxAge(60*60*24*30); // 设置Cookie的有效期为30天 response.addCookie(newVisitCookie); %> 您上次访问本站的时间是:<%= lastVisitTime %> ``` 在上面的代码中,我们首先获取了当前时间,并通过`request.getCookies()`方法获取到了上次访问时间Cookie。如果没有找到该Cookie,则说明是用户首次访问,将上次访问时间设置为“首次访问”。 接着,我们创建了一个新的Cookie对象,并通过`response.addCookie()`方法将其添加到响应中。需要注意的是,我们通过`setMaxAge()`方法设置了Cookie的有效期为30天,这样用户下次访问时也能够获取到上次访问时间。 最后,我们通过JSP的表达式语言输出了上次访问时间。 希望这个示例能够帮到您,如果您有任何疑问,请随时问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值