案例:记住上一次访问时间
        1. 需求:
            1. 访问一个Servlet,如果是第一次访问,则提示:您好,欢迎您首次访问。
            2. 如果不是第一次访问,则提示:欢迎回来,您上次访问时间为:显示时间字符串

2. 分析:
            1. 可以采用Cookie来完成
            2. 在服务器中的Servlet判断是否有一个名为lastTime的cookie
                1. 有:不是第一次访问
                    1. 响应数据:欢迎回来,您上次访问时间为:2018年6月10日11:50:20
                    2. 写回Cookie:lastTime=2018年6月10日11:50:01
                2. 没有:是第一次访问
                    1. 响应数据:您好,欢迎您首次访问
                    2. 写回Cookie:lastTime=2018年6月10日11:50:00

注意点:

1. 获取PrintWriter流之前必须设置编码

 response.setContentType("text/html;charset=utf-8");

2. cookie中不能包含特殊字符,比如空格,所以要进行编码以及解码

 package cn.itcast.web.servlet;

 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("/cookieServlet")
public class CookieServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException {
// 获取PrintWriter流之前设置响应的消息体的数据格式以及编码
response.setHeader("content-type", "text/html;charset=utf-8"); // 1.获取所有Cookie
Cookie[] cookies = request.getCookies();
boolean flag = false; // 没有叫做lastTime名称的cookie // 2.遍历cookie数组
if (cookies != null) {
for (Cookie cookie : cookies) {
if (cookie.getName().equals("lastTime")) { // 不是第一次访问
flag = true; String value = cookie.getValue();
value = URLDecoder.decode(value, "utf-8"); // URL解码
response.getWriter().write("欢迎回来,您上次的访问时间是" + value); // 将cookie的value值改为此次登录的时间,重新发送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"); // URL编码,因为str_date中包含空格,如果不进行URL编码将会报错
cookie.setValue(str_date);
cookie.setMaxAge(30 * 24 *60 *60); // 设置cookie的存活时间
response.addCookie(cookie);
break;
}
}
} if (cookies == null || flag == false){ // 第一次访问
response.getWriter().write("<h1>您好,欢迎您首次访问<h1>"); 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(30 * 24 *60 *60);
response.addCookie(cookie);
} } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
}
05-28 13:24