Cookie 自动记录 上次访问时间

package com.itheima.demo3_usecookie;

import com.itheima.Utils.CookieUtils;

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;
import java.io.IOException;
import java.util.Date;

/**
 * @author ChenY@itheima.com
 * @date 2022/8/24 17:53
 */
@WebServlet("/demo10")
public class Servlet10 extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
    {
         /** 处理中文乱码*/
          request.setCharacterEncoding("utf-8");
          response.setContentType("text/html; charset=utf-8");


        // 获取到浏览器的全部cookie
        Cookie[] cookies = request.getCookies();

        // 调用工具类 查找 这些cookie 里面有没有
        Cookie cookie = CookieUtils.getCookie(cookies, "lastTime");


        // 判断 cookie lasttime 是否为空
        if (cookie == null)
        {
            // 获取当前时间
            Date date = new Date();

            // 将当前 时间转化成 毫秒值
            long time = date.getTime();

            // 为空 第一次登录 (并记录当前时间到cookie)
            // 创建cookie 对象
            Cookie cookie1 = new Cookie("lastTime", time+"");

            // 设置cookie 生存时间 和设置有效路径
            cookie1.setMaxAge(60*60);
            cookie1.setPath(request.getContextPath());


            // 将cookie响应到浏览器
            response.addCookie(cookie1);

            // 给予第一次登录提示
            response.getWriter().write("你是第一次登录");
        }else{
            // 不为空 说明不是第一次登录
            // 从cookie 中获取到 上次的访问时间

              // 获取距离上一次 访问时间 的时间戳
            String value = cookie.getValue();
              // 将毫秒值 转换成·date
            Date date = new Date(Long.parseLong(value));
              // 把date 转换成 指定格式的字符串
            String lastTime = date.toLocaleString();

            //  创建(相同的cookie) cookie 并记录当前系统时间
            Date date1 = new Date();
            long time = date1.getTime();
            Cookie cookie1 = new Cookie("lastTime", time + "");

            // 设置cookie 生存时间 和设置有效路径
            cookie1.setMaxAge(60*60);
            cookie1.setPath(request.getContextPath());


            // 将cookie响应到浏览器
            response.addCookie(cookie1);

            // 给予第一次登录提示
            response.getWriter().write("你上一次登录的时间是"+lastTime);


        }



    }

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值