iOS开发网络篇—简单介绍ASI框架的使用

简介:

说明:本文主要介绍网络编程中常用框架ASI的简单使用。

一、ASI简单介绍

ASI:全称是ASIHTTPRequest,外号“HTTP终结者”,功能十分强大。

ASI的实现基于底层的CFNetwork框架,因此运行效率很高。可惜作者早已停止更新,有一些潜在的BUG无人去解决

ASI的github地址

https://github.com/pokeb/asi-http-request

ASI的使用参考

http://www.cnblogs.com/dotey/archive/2011/05/10/2041966.html

http://www.oschina.net/question/54100_36184

二、ASI的使用

1导入

  下载并导入ASI框架,注意该框架依赖于Reachability.

  导入框架后,如果编译的话会出现一大堆的错误。其中一个最主要的原因是因为该框架是非ARC的。

思考:如果一个框架,其中很多文件都是非ARC的,那么应该如何进行设置?

  在这里,介绍最傻瓜的一种方法,通过进行如下的一些设置以解决问题。(注意:对于所有的asi框架中得文件都需要进行此番设置)

  设置完成后,还存在一些错误。产生这些错误的原因是ASI框架它依赖于下面的几个框架,把需要的框架添加后再编译,就不会有问题了。

  添加依赖的框架:

把所需的三个框架逐个添加到项目中

2发送网络请求(同步和异步*GET和POST请求)

示例程序代码:

复制代码
 1 #import "YYViewController.h"  2 #import "ASIHTTPRequest.h"  3 #import "ASIFormDataRequest.h"  4  5 @interface YYViewController ()<ASIHTTPRequestDelegate>
 6 @property(nonatomic,strong)ASIHTTPRequest *request;
 7  8 @end  9  10 @implementation YYViewController
 11  12 - (void)viewDidLoad
 13 {
 14  [super viewDidLoad];
 15 }
 16  17 -(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event  18 {
 19 //同步请求
 20 // [self sync];
 21 //异步请求
 22 // [self async1];  23  24  [self post];
 25 }
 26  27 #pragma mark-发送post请求
 28 -(void)post
 29 { //1.创建网络请求(POST)  30 NSURL *url=[NSURL URLWithString:@"http://127.0.0.1:8080/MJServer/login"];
 31 ASIFormDataRequest *request=[ASIFormDataRequest requestWithURL:url];
 32  33 //2.添加请求参数(请求体中得参数)  34 [request setPostValue:@"123" forKey:@"username"];
 35 [request setPostValue:@"123" forKey:@"pwd"];
 36  37 //3.发送请求  38  [request startAsynchronous];
 39  40 //4.监听  41 [request setStartedBlock:^{
 42 //开始  43 NSLog(@"该方法会覆盖代理方法中得对应方法");
 44  }];
 45  46 }
 47  48 -(void)dealloc
 49 {
 50 #warning 当控制器销毁的时候,清除并取消代理  51  [self.request clearDelegatesAndCancel];
 52  53 //如果是非arc的环境,那么还需要清空请求
 54 //self.request=Nil;  55 }
 56 #pragma mark-异步请求
 57 /**
 58  * 异步请求的第一种方式:设置代理,用代理方法监听
 59 */  60 -(void)async1
 61 {
 62 //1.创建网络请求(GET)  63 NSURL *url=[NSURL URLWithString:@"http://127.0.0.1:8080/MJServer/login?username=123&pwd=123"];
 64 self.request=[ASIHTTPRequest requestWithURL:url];
 65 //设置网络请求的延时为10秒钟  66 self.request.timeOutSeconds=10;
 67  68 //2.设置代理  69 self.request.delegate=self;
 70  71  72 //3.发送请求(异步请求)  73  [self.request startAsynchronous];
 74 }
 75  76 #pragma mark-异步请求的代理方法
 77 //请求开始的时候调用  78 -(void)requestStarted:(ASIHTTPRequest *)request
 79 {
 80  81 }
 82 //接收到服务器返回的数据时调用(数据量比较大的时候,这个方法会被调用多次,每次只能拿到部分数据)  83 -(void)request:(ASIHTTPRequest *)request didReceiveData:(NSData *)data
 84 {
 85  86 }
 87 //请求结束的时候调用(在该方法中拿到最终的数据)  88 -(void)requestFinished:(ASIHTTPRequest *)request
 89 {
 90 //request.responseData:服务器返回的所有数据,这个data已经拼接了接收到的所有数据  91 }
 92 //发送网络请求失败的时候调用  93 -(void)requestFailed:(ASIHTTPRequest *)request
 94 {
 95 }
 96  97 /**
 98  * 异步请求的第二种方式:selector,以设置代理为基本前提
 99 */ 100 -(void)async2
101 {
102 //1.创建网络请求(GET) 103 NSURL *url=[NSURL URLWithString:@"http://127.0.0.1:8080/MJServer/login?username=123&pwd=123"];
104 self.request=[ASIHTTPRequest requestWithURL:url];
105 //设置网络请求的延时为10秒钟 106 self.request.timeOutSeconds=10;
107 108 //2.设置代理 109 self.request.delegate=self;
110 111 //通过selector的方法,当请求开始的时候,由请求的代理即控制器调用start方法进行监听
112 //说明:该方法会覆盖代理方法 113  [self.request setDidStartSelector:@selector(start)];
114 115 //3.发送请求(异步请求) 116  [self.request startAsynchronous];
117 }
118 119 -(void)start
120 {
121 NSLog(@"该方法会覆盖代理方法中得对应方法");
122 }
123 124 /**
125  * 异步请求的第三种方式:使用block回调
126 */ 127 -(void)async3
128 {
129 //1.创建网络请求(GET) 130 NSURL *url=[NSURL URLWithString:@"http://127.0.0.1:8080/MJServer/login?username=123&pwd=123"];
131 self.request=[ASIHTTPRequest requestWithURL:url];
132 //设置网络请求的延时为10秒钟 133 self.request.timeOutSeconds=10;
134 135 //2.使用block回调监听 136 [self.request setStartedBlock:^{
137 //请求开始的时候调用 138  }];
139 [self.request setFailedBlock:^{
140 //请求失败的时候调用 141  }];
142 [self.request setDataReceivedBlock:^(NSData *data) {
143 //开始接收数据的时候调用 144  }];
145 [self.request setCompletionBlock:^{
146 //请求成功完成的时候调用 147  }];
148 149 //3.发送请求(异步请求) 150  [self.request startAsynchronous];
151 }
152 153 154 #pragma mark-同步请求
155 -(void)sync
156 {
157 //1.创建网络请求(GET) 158 NSURL *url=[NSURL URLWithString:@"http://127.0.0.1:8080/MJServer/login?username=123&pwd=123"];
159 ASIHTTPRequest *request=[ASIHTTPRequest requestWithURL:url];
160 //设置网络请求的延时为10秒钟 161 request.timeOutSeconds=10;
162 163 //2.发送请求(同步请求) 164  [request startSynchronous];
165 166 167 //3.检测服务器返回的结果 168 if (request.error) {//请求出错,比如超时 169 NSLog(@"请求超时,错误信息为%@",request.error);
170 }else//请求成功 171  {
172 //打印状态码和状态信息 173 NSLog(@"状态码---%d,状态信息---%@",request.responseStatusCode, request.responseStatusMessage);
174 //打印返回的数据的长度 175 NSLog(@"返回数据的长度--%d",request.responseData.length);
176 //将返回的数据转换为字符串 177 NSLog(@"返回的数据---%@",request.responseString);
178 179 //将服务器返回的数据解析为字典 180 NSDictionary *dictionary = [NSJSONSerialization JSONObjectWithData:request.responseData options:NSJSONReadingMutableLeaves error:Nil];
181 NSLog(@"%@",dictionary);
182  }
183 }
184 @end
复制代码

程序说明:

(1)同步发送请求打印的消息

(2)异步发送请求

ASI以异步的方式发送网络请求有三种方式,第一种是通过代理进行监听;第二种方法是通过block进行监听。还有一种方法时使用selector,这是建立在设置代理的基础之上的,调用的方法会覆盖代理方法。

第一种方法:

复制代码
 1 /**
 2  * 异步请求的第一种方式:设置代理,用代理方法监听
 3 */  4 -(void)async1
 5 {
 6 //1.创建网络请求(GET)  7 NSURL *url=[NSURL URLWithString:@"http://127.0.0.1:8080/MJServer/login?username=123&pwd=123"];
 8 self.request=[ASIHTTPRequest requestWithURL:url];
 9 //设置网络请求的延时为10秒钟 10 self.request.timeOutSeconds=10;
11 12 //2.设置代理 13 self.request.delegate=self;
14 15 16 //3.发送请求(异步请求) 17  [self.request startAsynchronous];
18 }
19 20 #pragma mark-异步请求的代理方法
21 //请求开始的时候调用 22 -(void)requestStarted:(ASIHTTPRequest *)request
23 {
24 25 }
26 //接收到服务器返回的数据时调用(数据量比较大的时候,这个方法会被调用多次,每次只能拿到部分数据) 27 -(void)request:(ASIHTTPRequest *)request didReceiveData:(NSData *)data
28 {
29 30 }
31 //请求结束的时候调用(在该方法中拿到最终的数据) 32 -(void)requestFinished:(ASIHTTPRequest *)request
33 {
34 //request.responseData:服务器返回的所有数据,这个data已经拼接了接收到的所有数据 35 }
36 //发送网络请求失败的时候调用 37 -(void)requestFailed:(ASIHTTPRequest *)request
38 {
39 }
复制代码

第二种方法:

复制代码
 1 /**
 2  * 异步请求的第二种方式:selector,以设置代理为基本前提
 3 */  4 -(void)async2
 5 {
 6 //1.创建网络请求(GET)  7 NSURL *url=[NSURL URLWithString:@"http://127.0.0.1:8080/MJServer/login?username=123&pwd=123"];
 8 self.request=[ASIHTTPRequest requestWithURL:url];
 9 //设置网络请求的延时为10秒钟 10 self.request.timeOutSeconds=10;
11 12 //2.设置代理 13 self.request.delegate=self;
14 15 //通过selector的方法,当请求开始的时候,由请求的代理即控制器调用start方法进行监听
16 //说明:该方法会覆盖代理方法 17  [self.request setDidStartSelector:@selector(start)];
18 19 //3.发送请求(异步请求) 20  [self.request startAsynchronous];
21 }
22 23 -(void)start
24 {
25 NSLog(@"该方法会覆盖代理方法中得对应方法");
26 }
复制代码

第三种方法:

复制代码
 1 /**
 2  * 异步请求的第三种方式:使用block回调
 3 */  4 -(void)async3
 5 {
 6 //1.创建网络请求(GET)  7 NSURL *url=[NSURL URLWithString:@"http://127.0.0.1:8080/MJServer/login?username=123&pwd=123"];
 8 self.request=[ASIHTTPRequest requestWithURL:url];
 9 //设置网络请求的延时为10秒钟 10 self.request.timeOutSeconds=10;
11 12 //2.使用block回调监听 13 [self.request setStartedBlock:^{
14 //请求开始的时候调用 15  }];
16 [self.request setFailedBlock:^{
17 //请求失败的时候调用 18  }];
19 [self.request setDataReceivedBlock:^(NSData *data) {
20 //开始接收数据的时候调用 21  }];
22 [self.request setCompletionBlock:^{
23 //请求成功完成的时候调用 24  }];
25 26 //3.发送请求(异步请求) 27  [self.request startAsynchronous];
28 }
复制代码

提示:block是ios4之后才引入的技术。

这两种方法各有优缺点

说明:如果要同时发送多个请求,他们都设置控制器为自己的代理,这样需要进行一些必要的判断。而如果各自都是有block这样的方式的话,那么将不会存在这些问题,多个请求之间相互不存在干扰。

  新的问题:如果又有block又设置了代理,那么情况是什么样子的呢?

  答案是block和相关的代理方法都会被调用。

(3)补充

提示:ASI中已经考虑到了线程安全的问题。

3.发送POST请求。

代码:

注意需要包含一个头文件

内部默认就是POST的。

注意add和set的区别,一个是添加(适用于多值参数),一个是覆盖(内部先remove,再add)。

服务器接收到的请求信息:

目录
相关文章
|
1月前
|
搜索推荐 数据管理 定位技术
iOS应用开发中有多种主流框架
iOS应用开发中有多种主流框架
165 60
|
1月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
6天前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
91 66
|
7天前
|
机器学习/深度学习 算法 PyTorch
基于图神经网络的大语言模型检索增强生成框架研究:面向知识图谱推理的优化与扩展
本文探讨了图神经网络(GNN)与大型语言模型(LLM)结合在知识图谱问答中的应用。研究首先基于G-Retriever构建了探索性模型,然后深入分析了GNN-RAG架构,通过敏感性研究和架构改进,显著提升了模型的推理能力和答案质量。实验结果表明,改进后的模型在多个评估指标上取得了显著提升,特别是在精确率和召回率方面。最后,文章提出了反思机制和教师网络的概念,进一步增强了模型的推理能力。
26 4
基于图神经网络的大语言模型检索增强生成框架研究:面向知识图谱推理的优化与扩展
|
25天前
|
人工智能 自然语言处理
WebDreamer:基于大语言模型模拟网页交互增强网络规划能力的框架
WebDreamer是一个基于大型语言模型(LLMs)的网络智能体框架,通过模拟网页交互来增强网络规划能力。它利用GPT-4o作为世界模型,预测用户行为及其结果,优化决策过程,提高性能和安全性。WebDreamer的核心在于“做梦”概念,即在实际采取行动前,用LLM预测每个可能步骤的结果,并选择最有可能实现目标的行动。
54 1
WebDreamer:基于大语言模型模拟网页交互增强网络规划能力的框架
|
17天前
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
|
21天前
|
Java 调度 Android开发
安卓与iOS开发中的线程管理差异解析
在移动应用开发的广阔天地中,安卓和iOS两大平台各自拥有独特的魅力。如同东西方文化的差异,它们在处理多线程任务时也展现出不同的哲学。本文将带你穿梭于这两个平台之间,比较它们在线程管理上的核心理念、实现方式及性能考量,助你成为跨平台的编程高手。
|
23天前
|
存储 前端开发 Swift
探索iOS开发:从新手到专家的旅程
本文将带您领略iOS开发的奇妙之旅,从基础概念的理解到高级技巧的掌握,逐步深入iOS的世界。文章不仅分享技术知识,还鼓励读者在编程之路上保持好奇心和创新精神,实现个人成长与技术突破。
|
26天前
|
安全 IDE Swift
探索iOS开发之旅:从初学者到专家
在这篇文章中,我们将一起踏上iOS开发的旅程,从基础概念的理解到深入掌握核心技术。无论你是编程新手还是希望提升技能的开发者,这里都有你需要的指南和启示。我们将通过实际案例和代码示例,展示如何构建一个功能齐全的iOS应用。准备好了吗?让我们一起开始吧!
|
1月前
|
JSON 数据处理 Swift
Swift 中的网络编程,主要介绍了 URLSession 和 Alamofire 两大框架的特点、用法及实际应用
本文深入探讨了 Swift 中的网络编程,主要介绍了 URLSession 和 Alamofire 两大框架的特点、用法及实际应用。URLSession 由苹果提供,支持底层网络控制;Alamofire 则是在 URLSession 基础上增加了更简洁的接口和功能扩展。文章通过具体案例对比了两者的使用方法,帮助开发者根据需求选择合适的网络编程工具。
29 3