用户登录:第一次登录,显示这是您第一次访问,下次登录显示上次登录时间

该功能以下主要通过cookie方法来实现。

cookie部分源码如下:

package com.hqyj.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("/lastTimeServlet")
public class lastTimeServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        resp.setContentType("text/html;charset=utf-8");
        String username = req.getParameter("username");
        String password = req.getParameter("password");
        //此处用户名和密码设定后,只能通过下方用户名和密码登录
        if("zhangsan".equals(username)&&"123456".equals(password)) {
            boolean isFirst = true;
            Cookie[] cookies = req.getCookies();
            String lastTime = null;
            if (cookies != null) {
                for (Cookie cookie : cookies) {
                    if ("lastTime".equals(cookie.getName())) {
                        isFirst = false;
                        lastTime = cookie.getValue();
                        String decode = URLDecoder.decode(lastTime);
                        resp.getWriter().write("欢迎回来,您上次登录的时间为:" + decode);
                    }
                }
            }
            if(isFirst){
                resp.getWriter().write("这是您第一次登录");
            }
        }else {
            req.setAttribute("msg","用户名或密码错误");
            req.getRequestDispatcher("/login2.jsp").forward(req,resp);
        }
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String encode = URLEncoder.encode(sdf.format(new Date()));
        Cookie cookie =new Cookie("lastTime",encode);
        cookie.setMaxAge(60*60);
        resp.addCookie(cookie);

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

web部分源码如下:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<form action="/lastTimeServlet" method="post">
    用户名:<input name="username" type="text"><br>
    密码:<input name="password" type="password"><br>
    <button type="submit">提交</button>
</form>
<span style="color: red" >${requestScope.msg}</span>
</body>
</html>

运行效果如下:

需注意的是,设置的cookie存在的时间,当时间还未超过时,即便重新运行,页面显示的依旧是上次登录的时间。除非重新运行前已经手动删除了cookie。cookie可以在浏览器的历史纪录里面找到并可以手动删除。

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值