cookie案例(记住上次访问时间)

cookie案例之记住上次访问时间:

1.需求:
    1.访问一个servlet,如果是第一次访问,则提示:您好,欢迎首次访问
    2.如果不是第一次访问,则提示:欢迎回来,您上次访问时间为:时间字符串
2.分析:
    1.可以采用cookie完成
    2.在服务器中的servlet判断是否有一个名为lastTime的cookie
        1.有:不是第一次访问
            1.响应数据:欢迎回来,您上次访问时间为:xxx
            2.写回cookie:lastTime=xxx
        2.没有:是第一次访问
            1.响应数据:您好,欢迎首次访问
            2.写回cookie:lastTime=xxx
3.涉及知识点:
    Cookie及其方法
        getCookies(),
        addCookies(),
        setMaxAge()
    响应体数据输出:response.getWriter().writer()
    响应体数据格式及编码设置:response.setContentType()
    获取日期:Date对象
    格式化日期:SimpleDateFormat对象
    对cookie信息URL编码:URLEncoder.encode()
    对cookie信息URL解码:URLDecoder.decode()

注意:如果有特殊字符要注意URL转码,
        如500错误:An invalid character [32] was present in the Cookie value
        注意cookie.getValue()与cookie.setValue()顺序

CookieSetTime动态资源:

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("/setTime")
public class CookieSetTime extends HttpServlet {

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

    /*
        第一次访问
        不是第一次访问
     */
    // 设置消息体的数据格式及编码
    resp.setContentType("text/html;charset=utf-8");

    Cookie[] cookies = req.getCookies();
    // 标记是否有lastTime
    boolean flag = false;

    // 如果为null或者长度为0则没必要遍历数组消耗性能
    if (cookies != null && cookies.length > 0) {
        for (Cookie cookie : cookies) {

            String name = cookie.getName();
            if ("lastTime".equals(name)) {

                flag = true;
                String lastTimeValue = cookie.getValue();
                lastTimeValue = URLDecoder.decode(lastTimeValue, "utf-8");

                SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH时mm分ss秒");
                String strNewTime = sdf.format(new Date());
                strNewTime = URLEncoder.encode(strNewTime, "utf-8");

                cookie.setValue(strNewTime);
                cookie.setMaxAge(60*60*24*30);

                resp.addCookie(cookie);
                resp.getWriter().write("<h1>您上次访问时间:" + lastTimeValue + "</h1>");

                break;
            }
        }
    }

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

        SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH时mm分ss秒");
        String strNewTime = sdf.format(new Date());
        strNewTime = URLEncoder.encode(strNewTime, "utf-8");

        Cookie cookie = new Cookie("lastTime", strNewTime);
        cookie.setMaxAge(60*60*24*30);

        resp.addCookie(cookie);
        resp.getWriter().write("<h1>欢迎您首次访问</h1>");
    }
}

@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    this.doPost(req, resp);
}   
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值