iOS开发之ASI

2023-12-13 17:58
文章标签 开发 ios asi

本文主要是介绍iOS开发之ASI,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文将继续讲解网络编程,我们将使用第三方框架来实现网络编程。主要介绍两个框架:ASI 、AFN。本文主要介绍ASI。

利用ASI发送一个网络请求:同步请求、异步请求。需要向项目中导入库文件,如下:


同步请求

/***  同步请求*/
- (void)ASIsyncho {// 获取网络资源路径NSURL *url = [NSURL URLWithString:@"http://www.2cto.com/uploadfile/Collfiles/20140831/2014083109364172.gif"];// 创建请求//    ASIHTTPRequest *request = [[ASIHTTPRequest alloc] initWithURL:<#(NSURL *)#>];ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];// 设置请求超时request.timeOutSeconds = 10;// 发送请求(同步)[request startSynchronous];// 该行代码过掉,才会执行下面代码// 对返回数据,进行处理NSError *error = [request error];if (error) {NSLog(@"请求出错---%@", error);}else {// 请求成功// 获取数据NSData *data = [request responseData];// 网络数据NSLog(@"data - %zd", data.length);int status = [request responseStatusCode];// 状态码:200 OKNSLog(@"status - %d", status);}}

运行结果:

如果网络速度很慢或请求数据很大,程序将会卡在[requeststartSynchronous];

这一行,给用户不好的体验,我们基本上不使用同步的请求。

异步请求:代理方法、SEL回调、block回调

1.    代理方法

/***  异步请求(代理)*/
- (void)ASIasynchoDelegate {// 获取网络资源路径NSURL *url = [NSURL URLWithString:@"http://www.2cto.com/uploadfile/Collfiles/20140831/2014083109364172.gif"];// 创建请求//    ASIHTTPRequest *request = [[ASIHTTPRequest alloc] initWithURL:<#(NSURL *)#>];self.request = [ASIHTTPRequest requestWithURL:url];// 设置请求超时self.request.timeOutSeconds = 10;// 设置代理,遵循ASIHTTPRequestDelegate协议self.request.delegate = self;// ASIHTTPRequestDelegate// 发送异步请求,ASI通过代理的方式处理异步请求,请求成功、失败都会通知代理[self.request startAsynchronous];
}#pragma mark - ASIHTTPRequestDelegate
/***  请求开始时调用*/
- (void)requestStarted:(ASIHTTPRequest *)request {NSLog(@"requestStarted----");
}/***  请求成功结束时调用*/
- (void)requestFinished:(ASIHTTPRequest *)request {NSLog(@"requestFinished----");
}/***  请求出错时调用*/
- (void)requestFailed:(ASIHTTPRequest *)request {NSLog(@"requestFailed----");
}/***  有数据返回时调用*/
- (void)request:(ASIHTTPRequest *)request didReceiveData:(NSData *)data {NSLog(@"didReceiveData---- %zd", data.length);
}

注意:应当在控制器被销毁的时候,取消请求,如下:

- (void)dealloc {[self.request clearDelegatesAndCancel];self.request = nil;
}

运行结果:

可见协议方法request:didReceiveData:被调用的很频繁,和之前讲过的NSURLConnection很相似。

2.    SEL回调

/***  异步请求(SEL回调方法)*/
- (void)ASIasynchoSEL {// 获取网络资源路径NSURL *url = [NSURL URLWithString:@"http://www.2cto.com/uploadfile/Collfiles/20140831/2014083109364172.gif"];// 创建请求//    ASIHTTPRequest *request = [[ASIHTTPRequest alloc] initWithURL:<#(NSURL *)#>];self.request = [ASIHTTPRequest requestWithURL:url];// 设置请求超时self.request.timeOutSeconds = 10;[self.request setDelegate:self];// 还需要设置代理// 请求成功、失败都会回调相应的方法// 请求开始回调[self.request setDidStartSelector:@selector(asynchoRequestStarted)];// 请求失败回调[self.request setDidFailSelector:@selector(asynchoRequestFailed)];// 请求成功结束回调[self.request setDidFinishSelector:@selector(asynchoRequestFinished)];// 接受到请求头回调[self.request setDidReceiveResponseHeadersSelector:@selector(asynchoRequestHeader)];// 发送异步请求[self.request startAsynchronous];
}- (void)asynchoRequestStarted {NSLog(@"asynchoRequestStarted--");
}
- (void)asynchoRequestFailed {NSLog(@"asynchoRequestFailed--");
}
- (void)asynchoRequestFinished {NSLog(@"asynchoRequestFinished--");
}
- (void)asynchoRequestHeader {NSLog(@"-----%@", self.request.responseHeaders);}
注意:上面的代理中也设置的ASIHTTPRequest对象的代理,所以也要再控制器销毁的时候,取消请求,如下:

- (void)dealloc {[self.request clearDelegatesAndCancel];self.request = nil;
}

运行结果:


3.    block回调

/***  异步请求(block回调方法)*/
- (void)ASIasynchoBlock {// 获取网络资源路径NSURL *url = [NSURL URLWithString:@"http://www.2cto.com/uploadfile/Collfiles/20140831/2014083109364172.gif"];// 创建请求//    ASIHTTPRequest *request = [[ASIHTTPRequest alloc] initWithURL:<#(NSURL *)#>];self.request = [ASIHTTPRequest requestWithURL:url];// 设置请求超时self.request.timeOutSeconds = 10;__weak typeof(self) weakSelf = self;// 请求出错[self.request setStartedBlock:^{NSLog(@"setStartedBlock---");}];// 请求出错[self.request setFailedBlock:^{NSLog(@"setFailedBlock---");}];// 请求成功完成[self.request setCompletionBlock:^{NSLog(@"setCompletionBlock---");NSData *responseData = [weakSelf.request responseData];NSLog(@"数据--- %zd", responseData.length);}];[self.request setBytesReceivedBlock:^(unsigned long long size, unsigned long long total) {NSLog(@"setBytesReceivedBlock---size = %lld", size);}];[self.request startAsynchronous];
}

运行结果:


以上发送同步请求和异步请求都属于GET请求。还有一个小细节,发送请求后,会自动带有加载视图出现,如下:

利用ASI发送请求,我们可以获得服务器的各种响应,如下:

// 获得状态码、状态信息
@property (atomic, assign,readonly) int responseStatusCode;
@property (atomic, retain,readonly) NSString *responseStatusMessage;// 获得响应头
@property (atomic, retain) NSDictionary *responseHeaders;// 获得实体内容(响应体)
- (NSData *)responseData;
- (NSString *)responseString;

下面介绍一下利用ASI发送POST请求。需要包含ASIFormDataRequest.h头文件。下面简单使用一下:

- (void)ASIPOST {NSURL *url = [NSURL URLWithString:@""];// 创建请求ASIFormDataRequest *request = [ASIFormDataRequest requestWithURL:url];// 设置请求体(请求参数)形如:username=shx&pwd=123456[request setPostValue:@"shx" forKey:@"username"];[request setPostValue:@"123456" forKey:@"pwd"];// 发送POST请求
//    [request startSynchronous];// 同步[request startAsynchronous];// 异步//输入返回的信息NSLog(@"response\n%@",[request responseString]);
}

下面介绍一下利用ASI进行文件下载操作,ASI进行文件下载,只需要设置文件存储路径即可。如下:

/***  文件下载*/
- (void)fileDownLoad {// 得到文件下载路径NSURL *url = [NSURL URLWithString:@"http://..."];ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];// 文件存储路径(将文件存储在什么地方)NSString *path = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) lastObject];NSString *filePath = [path stringByAppendingPathComponent:@"abc.zip"];// 设置文件存储路径request.downloadDestinationPath = filePath;// 设置下载代理,遵循ASIProgressDelegate协议(其实只要实现了setProgress:方法,都可以成为它的代理对象,如:UIProgressView对象)request.downloadProgressDelegate = self;// 还可以设置是否支持断点下载request.allowResumeForFileDownloads = YES;// 发送请求,下载[request startAsynchronous];
}
#pragma mark 进度代理方法
- (void)setProgress:(float)newProgress
{NSLog(@"-----%f", newProgress);
}

下面是简单的文件上传功能的实现,,如下:

/***  文件上传*/
- (void)fileUpLoad {ASIFormDataRequest *request = [ASIFormDataRequest requestWithURL:[NSURL URLWithString:@""]];// 添加普通参数[request setPostValue:@"shx" forKey:@"user"];// 添加文件参数NSString *file = [[NSBundle mainBundle] pathForResource:@"1.png" ofType:nil];[request addFile:file forKey:@"file"];// 下面代码也可以上传1.png图片
//    UIImage *image = [UIImage imageNamed:@"1.png"];
//    NSData *data = UIImagePNGRepresentation(image);
//    [request addData:data withFileName:@"test.png" andContentType:@"image/png" forKey:@"file"];// test.png是存储到本地时候的图片名// 发送请求,上传[request startAsynchronous];
}
2 种添加文件参数的方法
// 通过文件的全路径
- (void)addFile:(NSString *)filePath forKey:(NSString *)key
- (void)addFile:(NSString *)filePath withFileName:(NSString *)fileName andContentType:(NSString *)contentType forKey:(NSString *)key// 通过文件的具体数据
- (void)addData:(id)data withFileName:(NSString *)fileName andContentType:(NSString *)contentType forKey:(NSString *)key

关于ASI网络编程注意点:

实际上ASIHTTPRequest继承自NSOperation,意味着

可以将多个ASIHTTPRequest放到NSOperationQueue中,同时管理多个请求

可以设置请求之间的依赖

… …

ASIFormDataRequest继承自ASIHTTPRequest

其他的一些用法

// 现在是否有网络请求在处理中
[ASIHTTPRequest isNetworkInUse];// 当正在请求时,是否要在状态栏显示联网状态(转圈圈)
[ASIHTTPRequest setShouldUpdateNetworkActivityIndicator:YES];// 当应用后台运行时,是否仍然继续处理网络请求
request.shouldContinueWhenAppEntersBackground = YES;// 设置请求超时后重试的次数
request.numberOfTimesToRetryOnTimeout = 2; // 重试2次

ASI还提供了缓存功能。ASI只能缓存Get请求的响应数据。关于ASI的缓存策略这里不做介绍。

这篇关于iOS开发之ASI的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/489387

相关文章

iOS HTTPS证书不受信任解决办法

之前开发App的时候服务端使用的是自签名的证书,导致iOS开发过程中调用HTTPS接口时,证书不被信任 - (void)URLSession:(NSURLSession *)session didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAu

Eclipse+ADT与Android Studio开发的区别

下文的EA指Eclipse+ADT,AS就是指Android Studio。 就编写界面布局来说AS可以边开发边预览(所见即所得,以及多个屏幕预览),这个优势比较大。AS运行时占的内存比EA的要小。AS创建项目时要创建gradle项目框架,so,创建项目时AS比较慢。android studio基于gradle构建项目,你无法同时集中管理和维护多个项目的源码,而eclipse ADT可以同时打开

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

WDF驱动开发-WDF总线枚举(一)

支持在总线驱动程序中进行 PnP 和电源管理 某些设备永久插入系统,而其他设备可以在系统运行时插入和拔出电源。 总线驱动 必须识别并报告连接到其总线的设备,并且他们必须发现并报告系统中设备的到达和离开情况。 总线驱动程序标识和报告的设备称为总线的 子设备。 标识和报告子设备的过程称为 总线枚举。 在总线枚举期间,总线驱动程序会为其子 设备创建设备对象 。  总线驱动程序本质上是同时处理总线枚

JavaWeb系列六: 动态WEB开发核心(Servlet) 上

韩老师学生 官网文档为什么会出现Servlet什么是ServletServlet在JavaWeb项目位置Servlet基本使用Servlet开发方式说明快速入门- 手动开发 servlet浏览器请求Servlet UML分析Servlet生命周期GET和POST请求分发处理通过继承HttpServlet开发ServletIDEA配置ServletServlet注意事项和细节 Servlet注

手把手教你入门vue+springboot开发(五)--docker部署

文章目录 前言一、前端打包二、后端打包三、docker运行总结 前言 前面我们重点介绍了vue+springboot前后端分离开发的过程,本篇我们结合docker容器来研究一下打包部署过程。 一、前端打包 在VSCode的命令行中输入npm run build可以打包前端代码,出现下图提示表示打包完成。 打包成功后会在前端工程目录生成dist目录,如下图所示: 把

Sapphire开发日志 (十) 关于页面

关于页面 任务介绍 关于页面用户对我组工作量的展示。 实现效果 代码解释 首先封装一个子组件用于展示用户头像和名称。 const UserGrid = ({src,name,size,link,}: {src: any;name: any;size?: any;link?: any;}) => (<Box sx={{ display: "flex", flexDirecti

IOS 数组去重的几种方式

本来只知道NSSet和KeyValues的。今天又新学了几种方式 还有就是和同事学的一种方式 外层循环从0开始遍历,内层从最后一个元素开始遍历 for(int i=0;i<index;i++){  for(int j=index-1;j>i;j-- ){ } }

iOS Assertion failure in -[UITableView _classicHeightForRowAtIndexPath:]

iOS Assertion failure in -[UITableView _classicHeightForRowAtIndexPath:]  2015-04-24 11:40  956人阅读  评论(0)  收藏  举报   分类:   iOS 基础篇(208)  版权声明:本文为博主原创文章,未经博主允许不得转载。 Assertion

ROS2从入门到精通4-4:局部控制插件开发案例(以PID算法为例)

目录 0 专栏介绍1 控制插件编写模板1.1 构造控制插件类1.2 注册并导出插件1.3 编译与使用插件 2 基于PID的路径跟踪原理3 控制插件开发案例(PID算法)常见问题 0 专栏介绍 本专栏旨在通过对ROS2的系统学习,掌握ROS2底层基本分布式原理,并具有机器人建模和应用ROS2进行实际项目的开发和调试的工程能力。 🚀详情:《ROS2从入门到精通》 1 控制插