iOS网络编程之四——请求类NSURLRequest使用详解-阿里云开发者社区

开发者社区> 珲yy少> 正文

iOS网络编程之四——请求类NSURLRequest使用详解

简介: iOS网络编程之四——请求类NSURLRequest使用详解
+关注继续查看



一、引言


       在前面几篇博客中,介绍了iOS开发中的网络编程相关内容并且介绍了常用了两个平行的网络框架NSURLSession和NSURLConnection。无论是NSURLSession类还是NSURLConnection类,其网络请求都是通过NSURLRequest类进行发起的,本篇博客将介绍NSURLRequest类的用法和其中请求属性的设置。


       前几篇博客地址如下:


1.iOS网络框架介绍:http://my.oschina.net/u/2340880/blog/618460


2.NSURLSesstion的使用:http://my.oschina.net/u/2340880/blog/618888


3.NSURLConnection的使用:http://my.oschina.net/u/2340880/blog/618920


二、NSURLRequest类中常用方法和属性总结


//通过类方法创建默认的请求对象

/*

通过这种方式创建的请求对象 默认使用NSURLRequestUseProtocolCachePolicy缓存逻辑 默认请求超时时限为60s

*/

+ (instancetype)requestWithURL:(NSURL *)URL;

//返回一个BOOL值 用于判断是否支持安全编码

+ (BOOL)supportsSecureCoding;

//请求对象的初始化方法 创建时设置缓存逻辑和超时时限

+ (instancetype)requestWithURL:(NSURL *)URL cachePolicy:(NSURLRequestCachePolicy)cachePolicy timeoutInterval:(NSTimeInterval)timeoutInterval;

//init方法进行对象的创建 默认使用NSURLRequestUseProtocolCachePolicy缓存逻辑 默认请求超时时限为60s

- (instancetype)initWithURL:(NSURL *)URL;

//init方法进行对象的创建

- (instancetype)initWithURL:(NSURL *)URL cachePolicy:(NSURLRequestCachePolicy)cachePolicy timeoutInterval:(NSTimeInterval)timeoutInterval;

//只读属性 获取请求对象的URL

@property (nullable, readonly, copy) NSURL *URL;

//只读属性 缓存策略枚举

/*

NSURLRequestCachePolicy枚举如下:

typedef NS_ENUM(NSUInteger, NSURLRequestCachePolicy)

{

   //默认的缓存协议

   NSURLRequestUseProtocolCachePolicy = 0,

   //无论有无本地缓存数据 都进行从新请求

   NSURLRequestReloadIgnoringLocalCacheData = 1,

   //忽略本地和远程的缓存数据 未实现的策略

   NSURLRequestReloadIgnoringLocalAndRemoteCacheData = 4,

   //无论有无缓存数据 都进行从新请求

   NSURLRequestReloadIgnoringCacheData = NSURLRequestReloadIgnoringLocalCacheData,

   //先检查缓存 如果没有缓存再进行请求

   NSURLRequestReturnCacheDataElseLoad = 2,

   //类似离线模式,只读缓存 无论有无缓存都不进行请求

   NSURLRequestReturnCacheDataDontLoad = 3,

   //未实现的策略

   NSURLRequestReloadRevalidatingCacheData = 5, // Unimplemented

};

*/

@property (readonly) NSURLRequestCachePolicy cachePolicy;

//只读属性 获取请求的超时时限

@property (readonly) NSTimeInterval timeoutInterval;

//请求主文档地址

@property (nullable, readonly, copy) NSURL *mainDocumentURL;

//获取网络请求的服务类型 枚举如下

/*

typedef NS_ENUM(NSUInteger, NSURLRequestNetworkServiceType)

{

   NSURLNetworkServiceTypeDefault = 0, // Standard internet traffic

   NSURLNetworkServiceTypeVoIP = 1, // Voice over IP control traffic

   NSURLNetworkServiceTypeVideo = 2, // Video traffic

   NSURLNetworkServiceTypeBackground = 3, // Background traffic

   NSURLNetworkServiceTypeVoice = 4    // Voice data

};

*/

@property (readonly) NSURLRequestNetworkServiceType networkServiceType;

//获取是否允许使用服务商蜂窝网络

@property (readonly) BOOL allowsCellularAccess;

NSURLRequest请求类除了在初始化时可以设定一些属性,创建出来后则大部分属性都为只读的,无法设置与修改。另一个类NSMutableURLRequest可以更加灵活的设置请求的相关属性。


三、NSMutableURLRequest类中常用方法与属性总结


//设置请求的URL

@property (nullable, copy) NSURL *URL;

//设置请求的缓存策略

@property NSURLRequestCachePolicy cachePolicy;

//设置超时时间

@property NSTimeInterval timeoutInterval;

//请求主文档地址

@property (nullable, copy) NSURL *mainDocumentURL;

//设置网络服务类型

@property NSURLRequestNetworkServiceType networkServiceType NS_AVAILABLE(10_7, 4_0);

//设置是否允许使用服务商蜂窝网

@property BOOL allowsCellularAccess NS_AVAILABLE(10_8, 6_0);

四、NSURLRequest请求对象与HTTP/HTTPS协议相关请求的属性设置


       一下属性的设置必须使用NSMutableURLRequest类,如果是NSURLRequest,则只可以读,不可以修改。


//设置HPPT请求方式 默认为“GET”

@property (copy) NSString *HTTPMethod;

//通过字典设置HTTP请求头的键值数据

@property (nullable, copy) NSDictionary<NSString *, NSString *> *allHTTPHeaderFields;

//设置http请求头中的字段值

- (void)setValue:(nullable NSString *)value forHTTPHeaderField:(NSString *)field;

//向http请求头中添加一个字段

- (void)addValue:(NSString *)value forHTTPHeaderField:(NSString *)field;

//设置http请求体 用于POST请求

@property (nullable, copy) NSData *HTTPBody;

//设置http请求体的输入流

@property (nullable, retain) NSInputStream *HTTPBodyStream;

//设置发送请求时是否发送cookie数据

@property BOOL HTTPShouldHandleCookies;

//设置请求时是否按顺序收发 默认禁用 在某些服务器中设为YES可以提高网络性能

@property BOOL HTTPShouldUsePipelining;

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
在与SQL Server建立连接时出现与网络相关的或特定于实例的错误
        向往前一样,学习牛腩新闻发布系统的视频,敲代码,打开数据库,出现一个框框,详细内容如下:                 数据库连接不上,所有的工作都要歇班,捣鼓了会儿,简单总结一下解决该问题的方法。
1232 0
iOS网络编程之三——NSURLConnection的简单使用
iOS网络编程之三——NSURLConnection的简单使用
36 0
iOS网络编程之二——NSURLSession的简单使用
iOS网络编程之二——NSURLSession的简单使用
16 0
flutter网络dio框架公共请求参数、请求header使用总结
> 本文章将讲述 > 1.get请求中配置公共参数 > 2.post请求配置公共参数 > 3.请求header配置
564 0
ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!)
原文:ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!) ORACLE PL/SQL编程之六: 把过程与函数说透(穷追猛打,把根儿都拔起!)   继上篇:ORACLE PL/SQL编程之八:把触发器说透 得到了大家的强力支持,感谢。
773 0
IOS UIButton使用详解
<p style="margin:10px auto; padding-top:0px; padding-bottom:0px; color:rgb(57,57,57); font-family:verdana,'ms song',Arial,Helvetica,sans-serif; font-size:14px; line-height:21px"> <span style="mar
1168 0
在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误
错误信息: 标题: 连接到服务器 ------------------------------ 无法连接到 (local)。 ------------------------------ 其他信息: 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider
1425 0
IOS使用CFURLCreateStringByAddingPercentEscapes进行URL编码
<p style="border-width:0px; padding-top:0px; padding-bottom:0px; margin-top:0px; margin-bottom:8px; list-style:none; text-indent:2em; color:rgb(51,51,51); font-family:宋体; font-size:14px; line-heig
1208 0
+关注
594
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载