开源中国iOS客户端学习——(五)网络通信ASI类库(1)

简介:

如今的应用大部分基予网络,在开源中国iOS客户端源码中关于网络通信方面用了三个类库,ASI和AFNetworking,还有一个苹果官方给出的Reachability用于检测当前网络状况,本文介绍当前用的比较多的ASI类库;


ASIHTTPRequest简称ASI,它是对CFNetwork API进行封装,使在与web服务器通信时的繁琐步骤变得容易一些。它是使用Objective-C 编写,能够很好的用在Mac OS X和iPhone应用程序中;它适用于执行基本的HTTP请求和交互基于 REST的服务(GET / POST / PUT /DELETE)互交。

ASIHTTPRequest下载 https://github.com/pokeb/asi-http-request/tree

关于ASI类库介绍在  http://allseeing-i.com/ASIHTTPRequest/

添加ASI到你工程中步骤 http://allseeing-i.com/ASIHTTPRequest/Setup-instructions


ASI特点

l通过简单的接口,即可完成向服务端提交数据和从服务端获取数据的工作 

l下载的数据,可存储到内存中或直接存储到磁盘中 

l能上传本地文件到服务端 

l可以方便的访问和操作请求和返回的Http头信息 

l可以获取到上传或下载的进度信息,为应用程序提供更好的体验 

l支持上传或下载队列,并且可获取队列的进度信息 

l支持基本、摘要和NTLM身份认证,在同一会话中授权凭证会自动维持,并且可以存储在KeychainMaciOS操作    系统的密码管理系统)中 

支持Cookie 

l当应用(iOS4+)在后台运行时,请求可以继续运行 

支持GZIP压缩数据 

l内置的ASIDownloadCache类,可以缓存请求返回的数据,这样即使没有网络也可以返回已经缓存的数据结果 

l ASIWebPageRequest –可以下载完整的网页,包括包含的网页、样式表、脚本等资源文件,并显示在UIWebView  /WebView中。任意大小的页面都可以无限期缓存,这样即使没有网络也可以离线浏览 

l支持客户端证书 

l支持通过代理发起Http请求 

l支持带宽限制。在iOS平台,可以根据当前网络情况来自动决定是否限制带宽,例如当使  用WWAN(GPRS/Edge/3G)网络时限制,而当使用WIFI时不做任何限制 

l支持断点续传 

l支持同步和异步请



ASI类库里包括22个文件,4个主要的类ASIHTTPRequest 、ASIFormDataRequest、ASINetworkQueue、ASIDownloadCache,5个支持的类ASIInputStream、ASIDataDecompressor、ASIDataCompressor、ASIAuthenticationDialog、Reachability,4个协议配置文件ASIHTTPRequestDelegate、ASIProgressDelegate、ASICacheDelegate、ASIHTTPRequestConfig.h,这些文件作用在开发文档中都有详细介绍.


http://allseeing-i.com/ASIHTTPRequest/How-to-use有关于初次接触ASI的简单使用,很有必要看一看,

了解简单的同步请求、异步请求,block块请求,队列请求等其他用法。


用ASI写的一个简单请求数据的Demo:

测试使用的URL是国家气象局API,返回一个json数据

#define URL @"http://www.weather.com.cn/data/sk/101010100.html"


请求得到数据:



//同步请求 - (IBAction)synchronization_bt:(id)sender {          NSURL *url = [NSURL URLWithString:URL];     ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url]; //    启动同步方式访问     [request startSynchronous];          NSError *error = [request error]; //    请求成功     if (!error) {         NSString *response = [request responseString];         NSLog(@"请求数据:%@",response);      }     }      } 

//异步请求 - (IBAction)asynchronous_bt:(id)sender {     NSURL *url = [NSURL URLWithString:URL];     ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];     [request setDelegate:self]; //    启动异步方式访问     [request startAsynchronous]; }   //异步请求Delegate Methods -(void)requestFinished:(ASIHTTPRequest *)request {     NSString *responseString = [request responseString];     NSLog(@"请求的String数据:%@",responseString); //   以 二进制文件形式存储     NSData *responseData = [request responseData];     NSLog(@"请求的Data数据:%@",responseData);      } -(void)requestFailed:(ASIHTTPRequest *)request {     NSError *error = [request error];     NSLog(@"Error:%@",error.userInfo);  }

//block块请求 - (IBAction)blocks_tn:(id)sender {     NSURL *url = [NSURL URLWithString:URL];     __block ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];     [request setCompletionBlock:^{         NSString *responseString = [request responseString];         NSLog(@"请求的String数据:%@",responseString);              }];     [request setFailedBlock:^{         NSError *error = [request error];          NSLog(@"Error:%@",error.userInfo);     }];     [request startAsynchronous]; }

//队列请求 - (IBAction)queue_bt:(id)sender {          if (![self queue]) {         [self setQueue:[[[NSOperationQueue alloc]init]autorelease]];     }     NSURL *url = [NSURL URLWithString:URL];     ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];     [request setDelegate:self];     [request setDidFinishSelector:@selector(requestDone:)];     [request setDidFailSelector:@selector(requestWentWrong:)];     [[self queue] addOperation:request]; }  -(void)requestDone:(ASIHTTPRequest *)request {     NSString *response = [request responseString];     NSLog(@"请求的数据:%@",response); }  -(void)requestWentWrong:(ASIHTTPRequest *)request {     NSError *error = [request error];     NSLog(@"Error:%@",error.userInfo); } 

将类库加入到工程中不要忘了添加支持的framework框架和库:

SystemConfiguration.framework, MobileCoreServices.framework, CoreGraphics.framework 和 libz.dylib.


源代码:http://download.csdn.net/detail/duxinfeng2010/4947729



ASIHTTPRequest中文文档:





正在学习过程中,错误之处请指正,欢迎交流,共同学习;

欢迎转载分享,请注明出处http://blog.csdn.net/duxinfeng2010



     本文转自新风作浪 51CTO博客,原文链接:http://blog.51cto.com/duxinfeng/1208689,如需转载请自行联系原作者




相关文章
|
28天前
|
JSON 中间件 Go
Go 网络编程:HTTP服务与客户端开发
Go 语言的 `net/http` 包功能强大,可快速构建高并发 HTTP 服务。本文从创建简单 HTTP 服务入手,逐步讲解请求与响应对象、URL 参数处理、自定义路由、JSON 接口、静态文件服务、中间件编写及 HTTPS 配置等内容。通过示例代码展示如何使用 `http.HandleFunc`、`http.ServeMux`、`http.Client` 等工具实现常见功能,帮助开发者掌握构建高效 Web 应用的核心技能。
164 61
|
29天前
|
运维 网络协议 Go
Go网络编程:基于TCP的网络服务端与客户端
本文介绍了使用 Go 语言的 `net` 包开发 TCP 网络服务的基础与进阶内容。首先简述了 TCP 协议的基本概念和通信流程,接着详细讲解了服务端与客户端的开发步骤,并提供了简单回显服务的示例代码。同时,文章探讨了服务端并发处理连接的方法,以及粘包/拆包、异常检测、超时控制等进阶技巧。最后通过群聊服务端的实战案例巩固知识点,并总结了 TCP 在高可靠性场景中的优势及 Go 并发模型带来的便利性。
|
5月前
|
监控 Linux PHP
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
144 20
|
5月前
|
监控 关系型数据库 MySQL
【01】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-硬件设备实时监控系统运营版发布-本产品基于企业级开源项目Zabbix深度二开-分步骤实现预计10篇合集-自营版
【01】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-硬件设备实时监控系统运营版发布-本产品基于企业级开源项目Zabbix深度二开-分步骤实现预计10篇合集-自营版
88 0
|
11月前
|
安全 网络安全 Android开发
安卓与iOS开发:选择的艺术网络安全与信息安全:漏洞、加密与意识的交织
【8月更文挑战第20天】在数字时代,安卓和iOS两大平台如同两座巍峨的山峰,分别占据着移动互联网的半壁江山。它们各自拥有独特的魅力和优势,吸引着无数开发者投身其中。本文将探讨这两个平台的特点、优势以及它们在移动应用开发中的地位,帮助读者更好地理解这两个平台的差异,并为那些正在面临选择的开发者提供一些启示。
171 56
|
9月前
|
存储 网络协议 Java
【网络】UDP回显服务器和客户端的构造,以及连接流程
【网络】UDP回显服务器和客户端的构造,以及连接流程
194 3
|
9月前
|
网络协议 Java API
【网络】TCP回显服务器和客户端的构造,以及相关bug解决方法
【网络】TCP回显服务器和客户端的构造,以及相关bug解决方法
147 2
|
9月前
|
安全 区块链 数据库
|
10月前
|
网络协议 C语言
C语言 网络编程(十)TCP通信创建流程---客户端
在TCP通信中,客户端需通过一系列步骤与服务器建立连接并进行数据传输。首先使用 `socket()` 函数创建一个流式套接字,然后通过 `connect()` 函数连接服务器。连接成功后,可以使用 `send()` 和 `recv()` 函数进行数据发送和接收。最后展示了一个完整的客户端示例代码,实现了与服务器的通信过程。
|
11月前
|
API Windows
揭秘网络通信的魔法:Win32多线程技术如何让服务器化身超级英雄,同时与成千上万客户端对话!
【8月更文挑战第16天】在网络编程中,客户/服务器模型让客户端向服务器发送请求并接收响应。Win32 API支持在Windows上构建此类应用。首先要初始化网络环境并通过`socket`函数创建套接字。服务器需绑定地址和端口,使用`bind`和`listen`函数准备接收连接。对每个客户端调用`accept`函数并在新线程中处理。客户端则通过`connect`建立连接,双方可通过`send`和`recv`交换数据。多线程提升服务器处理能力,确保高效响应。
111 6

热门文章

最新文章