需求
1. 访问一个Servlet,如果是第一次访问,则提示:您好,欢迎您首次访问。
2. 如果不是第一次访问,则提示:欢迎回来,您上次访问时间为:显示时间字符串
代码实现
package com.example.day16.cookie;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import javax.xml.crypto.Data;
import java.io.IOException;
import java.net.URLDecoder;
import java.net.URLEncoder;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
在服务器中的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:01
*/
@WebServlet("/CookieTest")
public class CookieTest extends HttpServlet {
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//设置响应的消息体的数据格式以及编码
response.setContentType("text/html;charset=utf-8");
//1.获取所有Cookie
Cookie[] cookies = request.getCookies();
boolean flag = false;//没有Cookie为lastTime
//2.遍历cookie数组
if(cookies !=null && cookies.length >0){
for (Cookie cookie : cookies) {
//获取cookie名称
String name = cookie.getName();
//4.判断名称是否是:LastTime
if("LastTime".equals(name)){
//有该Cookie,不是第一次访问
flag = true; //有lastTime的cookie
//设置cookie的value
//获取当前时间的字符串,重新设置Cookie的值,重新发送Cookie
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String str_date = sdf.format(date);
System.out.println("编码前:"+str_date);
//进行URL编码(主要解决刚刚格式化中的空格,如果不进行编码,运行时,会爆出500错误)
str_date = URLEncoder.encode(str_date,"utf-8");
System.out.println("编码后:"+str_date);
//覆盖以往的cookie值
cookie.setValue(str_date);
//设置cookie的存活时间
cookie.setMaxAge(60*60*24*30);//设置存活时间为一个月
//发送cookie
response.addCookie(cookie);
//响应数据
//获取Cookie的value,时间
String value = cookie.getValue();
System.out.println("解码前"+value);
//URL解码:因为前面进行编码,所以此处要进行解码,否则会出错并且不能阅读
value = URLDecoder.decode(value, "utf-8");
System.out.println("解码后"+value);
//输出欢迎语
response.getWriter().write("<h1>欢迎回来,您上次的登录时间为:"+value+"</h1>");
break;
}
}
}
if(cookies == null || cookies.length ==0 || flag == false){
//第一次访问
//设置cookie的value
//获取当前时间的字符串,重新设置Cookie的值,重新发送Cookie
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String str_date = sdf.format(date);
System.out.println("编码前:"+str_date);
//进行URL编码(主要解决刚刚格式化中的空格,如果不进行编码,运行时,会爆出500错误)
str_date = URLEncoder.encode(str_date,"utf-8");
System.out.println("编码后:"+str_date);
//覆盖以往的cookie值
Cookie cookie = new Cookie("LastTime",str_date);
cookie.setValue(str_date);
//设置cookie的存活时间
cookie.setMaxAge(60*60*24*30);//设置存活时间为一个月
//发送cookie
response.addCookie(cookie);
//响应数据
//获取Cookie的value,时间
String value = cookie.getValue();
System.out.println("解码前"+value);
//URL解码:因为前面进行编码,所以此处要进行解码,否则会出错并且不能阅读
value = URLDecoder.decode(value, "utf-8");
System.out.println("解码后"+value);
//输出欢迎语
response.getWriter().write("<h1>你好,欢迎首次登录</h1>");
}
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doGet(request, response);
}
}
运行结果