一个关于cookie的坑

时间:2022-06-25 17:39:30

#问题:今天上午踩了一个坑,首先,这个小案例的运行结果是应该是在前端页面出现一个当前时间的,当然如果是首次登陆的话应该是显示"第一次登陆",第二次则会显示上次的登录时间,但是却没有显示,首先看tomcat,会报一个异常IllegeArgumentException, 即非法参数异常, 一个关于cookie的坑

#总结:1)tomcat8.5及以上的版本不允许有空格,而空格在对应的ASCII是32;

2)习惯看tomcat日志以及debug ;

#以下是具体的DEMO:

Servlet文件:

package cn.itcast.chapter05.cookie.example;

import javax.servlet.ServletException;
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.text.SimpleDateFormat;
import java.util.Date; /**
* 需求:当用户访问某些Web应用时,经常会显示该用户上一次的访问时间。
* 实现:用Cookie技术实现显示用户上次的访问时间的功能。
* 本类:用于实现获取Cookie信息并将当前时间作为Cookie的值发送给客户端。
* */
public class LastAccessServlet extends HttpServlet {
private static final long serialVersionUID=1L;
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8"); String lastAccessTime=null; //获取所有的cookie,并将这些cookie存放当数组中
Cookie[] cookies=request.getCookies(); //遍历cookies数组
for (int i = 0; cookies!=null&&i<cookies.length; i++) {
if ("lastAccess".equals(cookies[i].getName())){
lastAccessTime=cookies[i].getValue();
break;
}
} //判断是否存在名称为lastAccess的cookie
if(lastAccessTime==null){
response.getWriter().print("你是首次访问本站!");
}else {
response.getWriter().print("你上次访问的时间是:"+lastAccessTime);
}
//创建cookie,将当前时间作为cookie的值发送给客户端
String currentTime=
new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss").format(new Date());
Cookie cookie=new Cookie("lastAccess",currentTime);
cookie.setMaxAge(60*60);
response.addCookie(cookie);
} }

web.xml文件,配置servlet路径。

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5"> <servlet>
<servlet-name>LastAccess</servlet-name>
<servlet-class>cn.itcast.chapter05.cookie.example.LastAccessServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>LastAccess</servlet-name>
<url-pattern>/LastAccess</url-pattern>
</servlet-mapping> </web-app>

#Cookie回忆:

1)概念:Cookie是保存在浏览器端的数据。

当浏览器访问服务器,服务器会发送一个set-cookie消息头给浏览器,当再次访问服务器时,会将

该消息头发送给服务器。

2)使用:

           1.添加Cookie
             Cookie c = new Cookie(String name,String value);
             注:
             Cookie只能存放字符串。
             response.addCookie(c);
           2.读取Cookie
             Cookie[] request.getCookies();
             String cookie.getName();
             String cookie.getValue();
             注: 有可能返回null。
             一个Cookie对象封装了一个Cookie中的数据。
 
#说明:

1.学会重复,与其敲三万行代码,不如把一万行代码敲三遍。

2.学会在集体中成长,学会借助外力。