一、cookie 简介
由于HTTP协议的无状态,客户端经常使用cookie来提供跨URL请求的数据持久存储。URL加载系统提供了创建和管理cookie的接口,作为HTTP请求的一部分发送cookies,并在Web服务器的响应时接收cookie。等多cookie信息请前往百度百科cookie
二、使用cookie
首先,正常业务场景下,cookie
最先是由服务器生成好
然后客服端请求接口,获取到cookie
,将cookie
存储起来。
最后,在每次网络请求的时候附带cookie
但是在iOS网络请求中使用cookie
还有1个条件,那就是在iOS中网络请求类NSURLRequest
中设置是否要使用cookie
/*!
决定这个请求是否要使用cookie,默认为YES
*/
@property BOOL HTTPShouldHandleCookies;
iOS 中cookie是一个NSHTTPCookie对象,它包含了各种各样的属性(properties)
// cookie 版本
// 版本0:此版本是指由Netscape定义的原始cookie格式的“传统”或“旧式”cookie。遇到的大多数Cookie都是这种格式。
// 版本1:此版本是指RFC 2965(HTTP状态管理机制)中定义的Cookie。
@property (readonly) NSUInteger version;
// cookie存储信息的名字,比如:token
@property (readonly, copy) NSString *name;
// cookie存储的信息,比如:8d2je219jjd0120d12e1212e12(token的值)
@property (readonly, copy) NSString *value;
// cookie有效期(过期,NSHTTPCookieStorage会自动删除存储的cookie)
@property (nullable, readonly, copy) NSDate *expiresDate;
// 是否应在会话结束时被丢弃(不管过期日期如何)
@property (readonly, getter=isSessionOnly) BOOL sessionOnly;
// cookie的域名
@property (readonly, copy) NSString *domain;
// 路径
@property (readonly, copy) NSString *path;
// 该cookie是否应该仅通过安全通道发送
@property (readonly, getter=isSecure) BOOL secure;
// 是否应仅根据RFC 2965发送到HTTP服务器
@property (readonly, getter=isHTTPOnly) BOOL HTTPOnly;
// 端口列表
@property (nullable, readonly, copy) NSArray *portList;
三、接收cookie
假设当前有这么一个场景,客服端中用户在登录时服务器将当前用户的token等相关信息存在cookie中返回给客户端,客户端在每次请求其他数据时都需要将此cookie信息(保存的用户信息)携带,以便区分当前是哪个用户。
那么我们要如何接收这个cookie
呢,iOS中提供了NSHTTPCookieStorage
这个类,来存储服务器给我们发送的cookie
,NSURLResponse
根据会当前的NSHTTPCookieStorage
接受策略自动接收返回的cookie并存储在NSHTTPCookieStorage
中,我们不需要做任何操作,在我们发送请求是,我们只需要设置HTTPShouldHandleCookies为YES(默认为YES)
, NSURLRequest
会自动附带cookie
的信息发送给服务器。以下是三种接收策略:
typedef NS_ENUM(NSUInteger, NSHTTPCookieAcceptPolicy) {
// 永远接收Cookie,这种情况下,NSHTTPCookieStorage会将接收到的cookie 存储在偏好设置中
NSHTTPCookieAcceptPolicyAlways,
// 永远不接受Cookie,这种情况下,NSHTTPCookieStorage不会存储cookie到本地
NSHTTPCookieAcceptPolicyNever,
// 只接收指定域名的Cookie
NSHTTPCookieAcceptPolicyOnlyFromMainDocumentDomain
};
NSHTPCookieStorage
对象是一个单例对象,它管理着所有的cookie,它提供了一些方法来允许客户端设置和移除cookie,和获取当前cookie的设置。
通过单例获取NSHTTPCookieStorage
对象
NSHTTPCookieStorage *cookieStorage = [NSHTTPCookieStorage sharedHTTPCookieStorage];
NSHTPCookieStorage
设置、删除、获取
// cookie的接收策略
@property NSHTTPCookieAcceptPolicy cookieAcceptPolicy
// 获取NSHTTPCookieStorage存储的所有cookie
@property (nullable , readonly, copy) NSArray *cookies
// 设置cookie
- (void)setCookie:(NSHTTPCookie *)cookie
// 删除cookie
- (void)deleteCookie:(NSHTTPCookie *)cookie
// 在某个时间点删除cookies
- (void)removeCookiesSinceDate:(NSDate *)date
// 获取指定URL的cookies
- (nullable NSArray *)cookiesForURL:(NSURL *)URL
// 获取指定域名指定URL的cookies
- (void)setCookies:(NSArray *)cookies forURL:(nullable NSURL *)URL mainDocumentURL:(nullable NSURL *)mainDocumentURL
四、清除cookie
还有一个场景需要清除cookie,那就是在客户端,用户退出登录,我们就需要删除NSHTPCookieStorage
中的cookie
NSArray *cookies = [[NSHTTPCookieStorage sharedHTTPCookieStorage] cookies];
for (NSHTTPCookie *cookie in cookies) {
[[NSHTTPCookieStorage sharedHTTPCookieStorage] deleteCookie:cookie];
}
五、总结
总体来说,使用cookie我们要确认三步信息:
1.NSURLRequest
是否允许使用cookie(HTTPShouldHandleCookies)
,默认允许。
2.NSHTTPCookieStorage
的接收策略
3.退出时清除NSHTTPCookieStorage
存储的cookie