javaweb之Cookie显示上次登录时间和清除Cookie、Cookie的细节

来源:互联网 发布:java接口定义静态方法 编辑:程序博客网 时间:2024/05/17 08:52
import java.io.IOException;import java.io.PrintWriter;import java.text.DateFormat;import java.text.SimpleDateFormat;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技术显示用户上次访问网站的时间public class CookieDemo1 extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {response.setCharacterEncoding("UTF-8");response.setHeader("Content-type", "text/html;charset=UTF-8");PrintWriter out = response.getWriter();out.print("<a href='/day07/servlet/CookieDemo2'>清除上次访问时间</a><br>");out.print("您上次访问的时间是:");// 拿到请求头中所有的cookieCookie cookies[] = request.getCookies();// 遍历cookies找到lastAccessTime这个cookiefor (int i = 0; cookies != null && i < cookies.length; i++) {if (cookies[i].getName().equals("lastAccessTime")) {// 得到最后访问时间的毫秒数long cookieValue = Long.parseLong(cookies[i].getValue());// 将最后访问时间变成一个日期类型Date date = new Date(cookieValue);// 格式化这个日期DateFormat df = new SimpleDateFormat("yyyy-MM-WW kk:mm:ss");String lastAccessTime = df.format(date);out.print(lastAccessTime);}}// 将最新的访问时间设置回去Cookie cookie = new Cookie("lastAccessTime", System.currentTimeMillis()+ "");// 设置有效期为一个月cookie.setMaxAge(1 * 3600 * 24 * 30);// 设置有效访问路径为/day07这个项目下的所有资源cookie.setPath("/day07");// 在response中增加一个cookie,服务器会自动增加Set-Cookie头字段response.addCookie(cookie);}public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {doGet(request, response);}}
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;//删除浏览器中的cookiepublic class CookieDemo2 extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {test1(response);test2(request, response);}// 自己实验的方法,拿到了原有的cookie想要删除还是要先设置下Path,否则Path还是会在这个servlet的目录下// 拿到了原有的cookie,如果只修改setMaxAge为0还是不行的!private void test2(HttpServletRequest request, HttpServletResponse response) {// 拿到请求头中所有的cookieCookie cookies[] = request.getCookies();// 遍历cookies找到lastAccessTime这个cookiefor (int i = 0; cookies != null && i < cookies.length; i++) {if (cookies[i].getName().equals("lastAccessTime")) {Cookie cookie = cookies[i];cookie.setMaxAge(0);cookie.setPath("/day07");response.addCookie(cookie);}}}// 开发中的方法private void test1(HttpServletResponse response) {Cookie cookie = new Cookie("lastAccessTime", "");// 设置为0表示让浏览器删除这个cookiecookie.setMaxAge(0);// 删除cookie的时候Path必须一致,因为同一个cookie,Path肯定一致cookie.setPath("/day07");response.addCookie(cookie);}public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {doGet(request, response);}}

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

5.             注意,删除cookie时,path必须一致,否则不会删除


0 0
原创粉丝点击