Cookie技术实现显示用户上次的访问时间的功能

—————————————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程序员

  • 17
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值