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<NSNumber *> *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<NSHTTPCookie *> *cookies

// 设置cookie
- (void)setCookie:(NSHTTPCookie *)cookie

// 删除cookie
- (void)deleteCookie:(NSHTTPCookie *)cookie

// 在某个时间点删除cookies
- (void)removeCookiesSinceDate:(NSDate *)date

// 获取指定URL的cookies
- (nullable NSArray<NSHTTPCookie *> *)cookiesForURL:(NSURL *)URL

// 获取指定域名指定URL的cookies
- (void)setCookies:(NSArray<NSHTTPCookie *> *)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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • iOS网络编程读书笔记 Facade Tester客户端门面模式的实例(被动版本化) 被动版本化,所以硬编码URL...
    melouverrr阅读 1,707评论 3 7
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,659评论 19 139
  • cookie机制采用的是在客户端保持 HTTP 状态信息的方案 Cookie是在浏览器访问WEB服务器的某个资源时...
    葛高召阅读 3,142评论 0 0
  • 目录 一、网络编程基础二、应用层通信协议三、HTTP协议演变过程四、请求(Request)和响应(Response...
    boundlessocean阅读 937评论 0 5
  • 为什么学编程 为什么选择Python 如何入门 为什么学编程 “你花了两个小时做了我们两天的工作!”同学去工作单位...
    肥猫FatCat阅读 1,302评论 1 3

友情链接更多精彩内容