iOS 深入浅出 网络编程之 NSHTTPCookie/NSHTTPCookieStorage

一、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

你可能感兴趣的:(iOS 深入浅出 网络编程之 NSHTTPCookie/NSHTTPCookieStorage)