首页 > 代码库 > Servlet中会话之cookie(7)
Servlet中会话之cookie(7)
(2).会话主要解决服务端如何保存每个客户端对应的私有信息。
(3).会话主要有二种:
a>Cookie技术[客户端技术]
b>Session技术
两者的不同就是:session会随着浏览器关闭而失效,但cookie会一直存放在客户端机器上,除非超出Cookie的生命周期。
2.Cookie技术
(1)Cookie是客户端技术,服务器把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去。这样,web资源处理的就是用户各自的数据了。
(2)一个Cookie只能存储一种类型的信息
(3)更新某个名的Cookie,即向浏览器写一个相同名的Cookie
(4)Cookie一定要设置一个有效时间,如果不设置的话,默认该请求访问结束后,该Cookie自动销毁,用专业名词来讲,Cookie的默认有效期时一个有效会话结束
3.Cookie的理解图
4.Cookie要注意的地方:
(1)一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。
(2)一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。
(3)浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
(4)如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。若希望浏览器将该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。
注意,删除cookie时,path必须一致,否则不会删除
5.代码小小练习:
package cn.wwh.www.web.cookie; import java.io.IOException; import java.io.PrintWriter; import java.net.URLDecoder; import java.net.URLEncoder; import javax.servlet.ServletException; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** *类的作用:用来练习cookie的创建和获取其中的数据值 注意1.对于返回的cookie一定对其进行非空的判断 * 2.对于编码方式采用UTF-8的方式,运行结果出现异常了, * 而采用 gbk的方式却正常输出,很是奇怪,(英文不需要转码) * * *@author 一叶扁舟 *@version 1.0 *@创建时间: 2014-8-1 下午04:52:31 */ public class CreateCookie extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 在服务端创建一个Cookie Cookie name = new Cookie("name", URLEncoder.encode("一叶扁舟", "gbk")); // 设置cookie的存活时间 name.setMaxAge(1 * 24 * 60 * 60); // 服务器将cookie写到客户端的缓存中 response.addCookie(name); // 取出客户端中所有的cookie Cookie[] allCookie = request.getCookies(); Cookie nameCookie = null; if (allCookie != null) { for (Cookie cookie : allCookie) { System.out.println("cookieName:" + cookie.getName()); if (cookie.getName().equals("name")) { nameCookie = cookie; break; } } } // 输出cookie的信息 System.out.println("cookie的name:" + nameCookie.getName()); System.out.println("cookie的value:" + URLDecoder.decode(nameCookie.getValue())); System.out.println("cookie的version:" + nameCookie.getVersion()); System.out.println("cookie的path:" + nameCookie.getPath()); System.out.println("cookie存活时间:" + nameCookie.getMaxAge()); } }
package cn.wwh.www.web.cookie; import java.io.IOException; 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; /** *类的作用:利用cookie技术,显示用户上次访问的时间 * * *@author 一叶扁舟 *@version 1.0 *@创建时间: 2014-8-1 下午08:38:14 */ public class ShowVisitedTime extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String name = request.getParameter("name"); if (name == null) { name = "default"; } // 获取客户端的cookie Cookie[] cookies = request.getCookies(); if (cookies == null) { Cookie nameCookie = new Cookie("name_" + name, System .currentTimeMillis() + ""); // 设置cookie缓存时间为一个小时 nameCookie.setMaxAge(1 * 60 * 60); // 写到客户端的缓存 response.addCookie(nameCookie); response.setContentType("text/html;charset=UTF-8"); response.getWriter().write( "欢迎" + "您首次光临本网站,当前时间为:" + new Date().toLocaleString()); } else { Cookie c = null; for (Cookie cookie : cookies) { // 找到了改用户之前登陆过 if (cookie.getName().equals("name_" + name)) { c = cookie; break; } } if (c != null) { response.setContentType("text/html;charset=UTF-8"); // 获取上次访问的时间 String lastTimeStr = c.getValue(); Long lastTime = Long.parseLong(lastTimeStr); response.getWriter().write( "欢迎" + "您再次访问本网站,上次访问时间为:" + new Date(lastTime).toLocaleString()); Cookie nameCookie = new Cookie("name_" + name, System .currentTimeMillis() + ""); // 设置cookie缓存时间为一个小时 nameCookie.setMaxAge(1 * 60 * 60); // 写到客户端的缓存 response.addCookie(nameCookie); } } } }
浏览器的效果图:
之后的刷新:
缓存文件的截图: