010.在产生时间字符串的时候出现了空格(whitespace),在创建cookie对象的时候是不允许的。

 

 

 

 

 

 

package cn.cookie.demo;

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.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.Date;

@WebServlet("/cookieDemo")
public class CookieDemo extends HttpServlet
{
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
    {
        /**
         * 1.获取当前时间
         * 2.以指定的模式 创建一个日期格式化对象
         * 3.创建一个日期对象,表示当前日期
         * 4.使用simpleDateFormat来格式化日期对象
         */
        //解决乱码
        req.setCharacterEncoding("utf-8");
        resp.setContentType("text/html;charset=utf-8");
        SimpleDateFormat simpleDateFormat=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        Date date=new Date();
        String time=simpleDateFormat.format(date);
        /**
         * 1.在产生时间字符串的时候出现了空格(whitespace),在创建cookie对象的时候是不允许的。
         * 2.在给客户端发送cookie的时候,将value进行"utf-8"编码,在获取客户端请求中的cookie时进行响应的"utf-8"解码,即可
         * 3.使用utf-8编码  time= URLEncoder.encode(time,"utf-8");
         * 4.使用utf-8解码  time = URLDecoder.decode(value,"utf-8");
         */
        time= URLEncoder.encode(time,"utf-8");
        //设置Cookie
        Cookie mycookie = new Cookie("mycookie",time);
        //持久化存储期限以秒为单位 4分钟=240秒
       // mycookie.setMaxAge(240);
        //设置浏览器解码格式为utf-8
        resp.setContentType("text/html;charset=utf-8");
        resp.addCookie(mycookie);
        /**
         * 1.对cookie进行判断
         * 2.获取所有的Cookie值
         * 3.若Cookie为空,说明第一次访问
         * 4.从Cookie数组中查找含有上一次访问时间的Cookie
         */
        Cookie[] cookies = req.getCookies();
        Cookie cookieTimeValue=null;
        //对Cookie进行解码
        if (cookies!=null)
        {
            //从Cookie数组中查找含有上一次访问时间的Cookie
            for (Cookie cookie:
                    cookies)
            {
                //若有,说明不是第一次访问
                if ("mycookie".equals(cookie.getName()))
                {
                    String valueTime=cookie.getValue();
                    //使用utf-8解码
                    valueTime= URLDecoder.decode(valueTime,"utf-8");
                    //设置解码后的值
                    cookie.setValue(valueTime);
                    cookieTimeValue=cookie;

                }
            }
        }
        if (cookieTimeValue!=null)
        {
            resp.getWriter().write("欢迎回来,您上次访问时间为:"+cookieTimeValue.getValue());
        }
        else
        {
            resp.getWriter().write("您好,欢迎您首次访问");
        }


    }

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

 

posted @ 2021-08-28 22:48  李林林  阅读(70)  评论(0编辑  收藏  举报