Cookie–记住上一次访问时间案例(Java)

Cookie–记住上一次访问时间案例(Java)Cookie 记住上一次访问时间案例 Java 博客说明 文章所涉及的资料来自互联网整理和个人总结 意在于个人学习和经验汇总 如有什么地方侵权 请联系本人删除 谢谢 需求 访问一个 Servlet 如果是第一次访问 则提示 您好 欢迎您首次访问 如果不是第一次访问 则提示 欢迎回来 您上次访问时间为 显示时间字符串 分析 可以采用 Cookie 来完成

Cookie–记住上一次访问时间案例(Java)

博客说明

文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢!
需求

访问一个Servlet,如果是第一次访问,则提示:您好,欢迎您首次访问。

如果不是第一次访问,则提示:欢迎回来,您上次访问时间为:显示时间字符串

分析

可以采用Cookie来完成

在服务器中的Servlet判断是否有一个名为lastTime的cookie

有:不是第一次访问

响应数据:欢迎回来,您上次访问时间为:2020年06月26日 10:52:29

写回Cookie:lastTime=2020年06月26日 10:52:29

没有:是第一次访问

响应数据:您好,欢迎您首次访问

写回Cookie:lastTime=2020年06月26日 10:52:29

代码
package cn.guizimo.cookie;

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.net.URLDecoder;
import java.net.URLEncoder;
import java.text.SimpleDateFormat;
import java.util.Date;

@WebServlet("/cookieTest")
public class CookieTest extends HttpServlet {

@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

//设置响应的编码
resp.setContentType("text/html;charset=utf-8");
boolean flag = false;

//获取所有的cookie
Cookie[] cookies = req.getCookies();
if (cookies != null && cookies.length > 0) {

for (Cookie cookie : cookies) {

String name = cookie.getName();
//判断是否第一次登录
if ("lastTime".equals(name)) {

//获取当前时间,重新发送cookie
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String str_date = sdf.format(date);
//编码
str_date = URLEncoder.encode(str_date, "utf-8");
cookie.setValue(str_date);
//设置存活时间,一个月
cookie.setMaxAge(60 * 60 * 24 * 30);
resp.addCookie(cookie);

//响应数据
String value = cookie.getValue();
//解码
value = URLDecoder.decode(value, "utf-8");
resp.getWriter().write("

欢迎回来,您上次的登录时间为:" + value + "

");
}
}
}
if (cookies == null || cookies.length == 0 || flag == false) {

//获取当前时间,重新发送cookie
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String str_date = sdf.format(date);
//编码
str_date = URLEncoder.encode(str_date, "utf-8");
Cookie cookie = new Cookie("lastTime", str_date);
//设置存活时间,一个月
cookie.setMaxAge(60 * 60 * 24 * 30);
resp.addCookie(cookie);

resp.getWriter().write("

欢迎首次访问

");
}
}

@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

this.doPost(req, resp);
}
}
测试

第一次访问

再次访问

感谢

黑马程序员
万能的网络
以及勤劳的自己
编程小号
上一篇 2025-07-13 08:06
下一篇 2025-10-06 14:30

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/121270.html