cookies学习常用API笔记

本文详细介绍了Java Servlet中Cookie的工作原理及使用方法。包括如何通过Servlet API创建和读取Cookie,设置Cookie的有效期、路径等属性,以及如何在客户端和服务端之间传递Cookie。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Cook

javax.servlet.http.Cookie类用于创建一个Cookie,response接口也中定义了一个addCookie方法,它用于在其响应头中增加一个相应的Set-Cookie头字段。 同样,request接口中也定义了一个getCookies方法,它用于获取客户端提交的Cookie。Cookie类的方法:

  1. public Cookie(String name,String value)
  2. setValue与getValue方法
  3. setMaxAge与getMaxAge方法
  4. setPath与getPath方法
  5. getName方法

显示用户上次访问时间

Cookie.setMaxAge(72460*60)
Cookie.setPath(“/day0X”);
Httpwatch观察
Cookie.setMaxAge(0)删除同名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 Demo1 extends HttpServlet {
    public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {
        /*
        //服务端产生Cookie
        Cookie cookie = new Cookie("username","haha");
        //设置Cookie存活时间
        cookie.setMaxAge(1*24*60*60);
        //服务端将Cookie写到客户端暂存
        response.addCookie(cookie);
        */

        //取得客户端所有的Cookie
        Cookie[] cookies = request.getCookies();
        Cookie usernameCookie = null;
        if(cookies!=null){
            for(Cookie c : cookies){
                if(c.getName().equals("username")){
                    usernameCookie = c;
                    break;
                }
            }
            //如果找到了Cookie
            if(usernameCookie!=null){
                System.out.println("Cookie的名字:" + usernameCookie.getName());
                System.out.println("Cookie的值:" + usernameCookie.getValue());
                System.out.println("Cookie的生命:" + usernameCookie.getMaxAge());
                System.out.println("Cookie的路径:" + usernameCookie.getPath());
            }
        }
    }
}

Cookie细节

一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。
一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。
浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。若希望浏览器将该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。
注意,删除cookie时,path必须一致,否则不会删除

转载于:https://blog.51cto.com/357712148/2105012

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值