—————————————Java后台语言—————————————
小编使用的是IDEA编码器,tomcat 8版本的服务器。
简单说明下Cookie类的构造方法,有且仅有一个,具体语法格式如下:
public Cookie(java.lang.String name,java.lang.String value)
接下来创建一个LastAccessServlet的Servlet类,该类主要用于实现获取Cookie信息并将当前时间作为Cookie值发送给客服端。
LastAccessServlet.java
import javax.servlet.ServletException;
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.text.SimpleDateFormat;
import java.util.Date;
/*
该类主要用于实现获取Cookie信息并将当前时间作为Cookie值发送给客户端
*/
public class LastAccessServlet extends HttpServlet {
private static final long serialVersionUID =1L;
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//指定服务器输出的内容的编码方式为utf-8,以防乱码
resp.setContentType("text/html;charset=utf-8");
String lastAccessTime = null;
//获取所有的Cookie,并将这些cookie存放在数组中
Cookie[] cookies = req.getCookies();
//遍历cookie数组
for (int i = 0;cookies != null && i<cookies.length ;i++){
//resp.getWriter().print(cookies[i].getName()+cookies[i].getValue());
if ("Cstao".equals(cookies[i].getName())){
//如果cookie的名称为lastAccess,则获取该cookie的值
lastAccessTime = cookies[i].getValue();
break;
}
}
//判断是否存在名称为lastAccess的cookie
if (lastAccessTime == null){
resp.getWriter().print("您是首次访问本站!");
}else {
resp.getWriter().print("你上次登录的时间——————" + lastAccessTime);
}
//创建cookie,将当前时间作为cookie的值发送给客户端
String currentTime = new SimpleDateFormat("yyyy-M-d:hh:mm:ss").format(new Date());
Cookie cookie = new Cookie("Cstao",currentTime);
cookie.setPath("/");
//发送cookie
resp.addCookie(cookie);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doPost(req,resp);
}
}
小编担心读者看上面的注释看的很辛苦,所以我就再梳理下思路。(比心小编~~~haha)
- 第19行代码: 定义一个lastAccessTime变量,用户保存用户上一次访问的时间;
- 第21行代码: 用户获取所有Cookie;
- 第23~30行代码: 遍历所有Cookie,判断其中名为Cstao的Cookie,且获取Cookie的值保存在lastAccessTime变量中;
- 第32~36行代码: 判断lastAccessTime是否为空(null);
- 第38~39行代码:记录当前访问的时间,并保存到Cstao的Cookie中;
- 第40行代码:设置Cookie路径,直接加 / 就行
- 第42行代码:用于向客服端发送Cookie。
这里需要注意的点就是要是500状态的话,那问题应该就是时间格式不对,不同版本的Tomcat时间要求格式就不同。小编使用的是Tomcat 8版本,使用下面的时间格式就能成功响应给客户端一个Cookie。
yyyy-M-d:hh:mm:ss
还有另外一种时间格式:
yyyy-MM-dd hh:mm:ss
因为这个问题,小编和自己的朋友检查到脑瓜疼。
最后配置映射信息查看运行结果
这是第二次刷新的结果,第一次访问的没截图。。。
———————Cstao一个行走在技术路上的Java程序员