Cookie对象

·cookie对象

浏览器的一种技术
通过浏览器的程序能将一些只须保存客户端,或者在客户端进行处理的数据,放在本地的计算机上,不需要通过网络传输;
cookie的大小在4kb左右,每个浏览器在同一域名下能存放cookie数量是有限的,谷歌浏览器大概是50个。
Cookie不跨浏览器,换电脑也无效。

优缺点:
提高网页的效率,减轻服务器的负载。
安全性较差。

Cookie的创建和发送

1、创建cookie

Cookie cookie = new Cookie("cookie的名称","cookie的值");
注:键和值都是字符串,不支持中文

2、发送cookie

response.addCookie(cookie对象);

3、获取cookie

response.getCookies();		返回的是所有的cookie的数组

4、Cookie的到期时间设置
注:Cookie是浏览器技术,关闭服务器不会影响cookie的变化
到期时间,到期时间用来指定该cookie何时失效。
默认为当前浏览器关闭即失效。

手动设定cookie的有效时间(通过到期时间计算)

通过setMaxAge(int time);方法设定cookie的最大有效时间,以秒为单位。

1)、【<-1】若为非-1的负数,则表示不储存该cookie;、
2)、【-1】cookie的maxAge属性的默认值就是-1,表示只在浏览器内存中存活,一旦关闭浏览器窗口,那么cookie就会消失。
3)、【0】当setMaxAge(0),表示cookie被作废!也就是说,如果原来浏览器已经保存了这个Cookie,那么可以通过Cookie的setMaxAge(0)来删除这个cookie。无论是在浏览器内存中,还是客户端磁盘上都会删除这个cookie。
4)、【>0】为cookie的存活时间,单位为秒。

5、cookie不能存中文
有中文则通过URLEncoder.encode()来进行编码;
获取时通过URLDecoder.decode()来进行编码;

6、cookie的覆盖
如果出现相同的cookie名称,则会覆盖原来的cookie(在相同的domian和path下!)

7、cookie的path
只有访问的地址包含cookie的path值时,才能得到cookie对象

		创建cookie
		Cookie cookie =  new Cookie("uname","admin");
		// 设置path (当前服务器下任意资源都可访问)
		cookie.setPath("/");
		// 发送cookie
		resp.addCookie(cookie);
		
		
		// 创建cookie
		Cookie cookie2 = new Cookie("userName","Lisa");
		// 设置path
		cookie2.setPath("/sc04/test/aa");
		// 发送cookie
		resp.addCookie(cookie2);
在Spring框架中,`ServerHttpRequest`对象没有直接提供获取Cookie对象的方法。但是您可以通过以下步骤来获取Cookie对象: 1. 使用`getHeaders()`方法获取请求头部信息。 2. 使用`getFirst(HttpHeaders.COOKIE)`方法获取名为`Cookie`的请求头。 3. 使用`org.springframework.http.HttpCookie.parse(String headerValue)`方法解析Cookie字符串并返回一个`List<HttpCookie>`对象。 4. 遍历该列表以获取每个Cookie对象。 以下是一个示例代码: ```java import org.springframework.http.HttpHeaders; import org.springframework.http.server.reactive.ServerHttpRequest; import org.springframework.util.CollectionUtils; import java.util.List; import java.util.Objects; public class CookieUtils { public static void printCookies(ServerHttpRequest request) { HttpHeaders headers = request.getHeaders(); List<String> cookieHeaders = headers.get(HttpHeaders.COOKIE); if (!CollectionUtils.isEmpty(cookieHeaders)) { cookieHeaders.forEach(cookieHeader -> { List<HttpCookie> cookies = HttpCookie.parse(cookieHeader); cookies.forEach(cookie -> { System.out.println("Name: " + cookie.getName()); System.out.println("Value: " + cookie.getValue()); System.out.println("Domain: " + cookie.getDomain()); System.out.println("Path: " + cookie.getPath()); System.out.println("Max-Age: " + cookie.getMaxAge()); System.out.println("Secure: " + cookie.getSecure()); System.out.println("HttpOnly: " + cookie.isHttpOnly()); }); }); } } } ``` 通过获取请求头中的`Cookie`头部信息,然后使用`HttpCookie.parse()`方法将其解析为`List<HttpCookie>`对象。然后遍历该列表以获取每个Cookie对象的属性。 请注意,以上示例是使用Spring WebFlux框架的示例。在其他框架或库中,可能会有一些差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值