使用cookie记录用户上一次访问的时间
- package gac.xdp.cookie;
-
- import java.io.IOException;
- import java.io.PrintWriter;
- import java.util.Date;
- import javax.servlet.ServletException;
- import javax.servlet.http.Cookie;
- import javax.servlet.http.HttpServlet;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
-
-
-
-
-
- public class CookieDemo01 extends HttpServlet {
-
- public void doGet(HttpServletRequest request, HttpServletResponse response)
- throws ServletException, IOException {
-
- response.setCharacterEncoding("UTF-8");
-
- response.setContentType("text/html;charset=UTF-8");
- PrintWriter out = response.getWriter();
-
- Cookie[] cookies = request.getCookies();
-
- if (cookies!=null) {
- out.write("您上次访问的时间是:");
- for (int i = 0; i < cookies.length; i++) {
- Cookie cookie = cookies[i];
- if (cookie.getName().equals("lastAccessTime")) {
- Long lastAccessTime =Long.parseLong(cookie.getValue());
- Date date = new Date(lastAccessTime);
- out.write(date.toLocaleString());
- }
- }
- }else {
- out.write("这是您第一次访问本站!");
- }
-
-
- <span style="color:#ff0000;"> Cookie cookie = new Cookie("lastAccessTime", System.currentTimeMillis()+"")</span>;
-
- response.addCookie(cookie);
- }
-
- public void doPost(HttpServletRequest request, HttpServletResponse response)
- throws ServletException, IOException {
- doGet(request, response);
- }
-
- }
在上面的例子中,在程序代码中并没有使用setMaxAge方法设置cookie的有效期,所以当关闭浏览器之后,cookie就失效了,要想在关闭了浏览器之后,cookie依然有效,那么在创建cookie时,就要为cookie设置一个有效期。如下所示:
-
- Cookie cookie = new Cookie("lastAccessTime", System.currentTimeMillis()+"");
-
- c<span style="color:#ff0000;">ookie.setMaxAge(24*60*60);</span>
-
- response.addCookie(cookie);
用户第一次访问时,服务器发送给浏览器的cookie就存储到了硬盘上。
这样即使关闭了浏览器,下次再访问时,也依然可以通过cookie获取用户上一次访问的时间。
Cookie注意细节
- 一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。
- 一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。
- 浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
- 如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。若希望浏览器将该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。
删除Cookie
注意:删除cookie时,path必须一致,否则不会删除
- package gac.xdp.cookie;
-
- import java.io.IOException;
-
- import javax.servlet.ServletException;
- import javax.servlet.http.Cookie;
- import javax.servlet.http.HttpServlet;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
-
-
-
-
-
- public class CookieDemo02 extends HttpServlet {
-
- public void doGet(HttpServletRequest request, HttpServletResponse response)
- throws ServletException, IOException {
-
- Cookie cookie = new Cookie("lastAccessTime", System.currentTimeMillis()+"");
-
- <span style="color:#ff0000;">cookie.setMaxAge(0);</span>
- response.addCookie(cookie);
- }
-
- public void doPost(HttpServletRequest request, HttpServletResponse response)
- throws ServletException, IOException {
- doGet(request, response);
- }
- }
cookie中存取中文
要想在cookie中存储中文,那么必须使用URLEncoder类里面的encode( s, enc)方法进行中文转码,例如:
- <span style="color:#ff0000;"> Cookie cookie = new Cookie("userName", URLEncoder.encode("孤傲苍狼", "UTF-8"));</span>
- response.addCookie(cookie);
在获取cookie中的中文数据时,再使用URLDecoder类里面的decode(
s,
enc)进行解码,例如:
- <span style="color:#ff0000;">URLDecoder.decode(cookies[i].getValue(), "UTF-8")</span>