ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Cookie特点&作用和Cookie案例

2022-08-15 10:32:18  阅读:157  来源: 互联网

标签:访问 特点 案例 Cookie date cookie lastTime response


Cookie的特点和作用:

  • cookie存储数据在客户端浏览器
  • 浏览器对于单个cookie的大小有限制(4kb)以及对同一个域名下的总cookie数量也有限制(20个)

作用:

  • cookie一般用于存储邵力那个的不太敏感的数据
  • 在不登陆的情况下,完成对服务器对客户端的身份识别

案例:记住上一次访问的时间

  • 需求:

    • 访问同一个Servlet,如果是第一次访问,则提示:您好,欢迎您首次访问
    • 如果不是第一次访问,则提示:欢迎回来,您上次访问的时间为:显示时间字符串
  • 分析:

    • 可以采用Cookie来完成
    • 在服务器中的Servlet判断是否有一个名为lastTime的Cookie
      • 有:不是第一次访问
        • 响应数据:欢迎回来您上次访问的时间为:"上次访问时间"
        • 写回Cookie:lastTime=当前时间
      • 没有:是第一次访问
        • 响应数据:您好,欢迎您首次访问
        • 写回Cookie:lastTime=当前时间

代码实现:

package com.ailyt.cookie;

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * 在服务器中的Servlet判断是否有一个名为lastTime的Cookie
 * 有:不是第一次访问
 * 响应数据:欢迎回来您上次访问的时间为:"上次访问时间"
 * 写回Cookie:lastTime=当前时间
 * 没有:是第一次访问
 * 响应数据:您好,欢迎您首次访问
 * 写回Cookie:lastTime=当前时间
 */
@WebServlet(name = "CookieTest", value = "/CookieTest")
public class CookieTest extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType("text/html;charset=urf-8");
        boolean flag = false;
        //获取所有Cookie
        Cookie[] cookies = request.getCookies();
        for (Cookie cookie : cookies) {
            if (cookie.getName().equals("lastTime")) {
                flag = true;
                Date date = new Date();
                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                String str_date = sdf.format(date);
                cookie.setValue(str_date);
                cookie.setMaxAge(60 * 60 * 24 * 30);
                response.addCookie(cookie);
                String value = cookie.getValue();
                response.getWriter().println("<h1>欢迎回来您上次访问的时间为-->" + value + "</h1>");
                cookie.setValue(new Date().toString());

                break;
            }
        }
        if (cookies == null || cookies.length < 0 || flag == false) {
            Date date = new Date();
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd  HH:mm:ss");
            String str_date = sdf.format(date);
            Cookie cookie = new Cookie("lastTime",str_date);
            cookie.setMaxAge(60 * 60 * 24 * 30);
            response.addCookie(cookie);
            response.getWriter().println("<h1>您好,欢迎您首次访问</h1>");
        }
    }
}

标签:访问,特点,案例,Cookie,date,cookie,lastTime,response
来源: https://www.cnblogs.com/ailhy/p/16587336.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有