本文意义
- 直接用代码演示了AFNetworking框架的基本用法
- 利用AFN发送GET、POST请求、文件上传等
- 本文以下代码测试的服务器是虚作的,如果真想在远程服务器测试,可以留言
什么是AFN
- 全称是AFNetworking,流行框架,在iOS开发中,使用比较广泛
- AFN的github地址
https://github.com/pokeb/AFNetworking/AFNetworking
AFN发送GET请求, 直接上代码,注意看注释
- AFHTTPSessionManager内部包装了NSURLSession
- 不用在URL后面拼接参数,传入一个参数数据就可以了
- 默认采用JSON解析了服务器响应的数据
- (void)get
{
// AFHTTPSessionManager内部包装了NSURLSession
AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];
NSDictionary *params = @{
@"username" : @"123",
@"pwd" : @"123"
};
[mgr GET:@"http://www.baidu.com/login" parameters:params success:^(NSURLSessionDataTask *task, id responseObject) {
NSLog(@"请求成功---%@", responseObject);
} failure:^(NSURLSessionDataTask *task, NSError *error) {
NSLog(@"请求失败---%@", error);
}];
}
AFN发送POST请求
- 只要将GET改为POST即可,其它跟GET请求一样
- (void)get
{
// AFHTTPSessionManager内部包装了NSURLSession
AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];
NSDictionary *params = @{
@"username" : @"123",
@"pwd" : @"123"
};
[mgr POST:@"http://www.baidu.com/login" parameters:params success:^(NSURLSessionDataTask *task, id responseObject) {
NSLog(@"请求成功---%@", responseObject);
} failure:^(NSURLSessionDataTask *task, NSError *error) {
NSLog(@"请求失败---%@", error);
}];
}
AFN上传文件
- 上传文件,AFN做了非常好的封装,建议以后采用AFN来上传文件,当然如果你想学习上传文件的底层代码,可以浏览我另一篇博文------文件上传
- (void)upload{
AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];
[mgr POST:@"http://www.baidu.com/upload" parameters:nil constructingBodyWithBlock:^(id<AFMultipartFormData> formData) {
// 这是最简单的版本,只要设置请求的URL、给出文件路径和name,便可将文件上传到服务器,后面有代码介绍其它方式
[formData appendPartWithFileURL:[NSURL fileURLWithPath:@"/Users/zhamengjun/Desktop/Swift Programming Language.epub"] name:@"file" error:nil];
} success:^(NSURLSessionDataTask *task, id responseObject) {
// 文件上传成功来到这段代码,注意responseObject的实际类型,AFN默认解析过
NSLog(@"------%@", responseObject);
} failure:^(NSURLSessionDataTask *task, NSError *error) {
NSLog(@"failure");
}];
}
- 常规的方式上传文件,需要指定URL、文件名、文件的MIMEType、name,上面的方式,只是AFN根据请求的URL,默认获取了文件名和文件的MIMEType
- 关于如何获取文件的MIMEType,请关注另一篇博文:获取文件的MIMEType
//创建data对象
NSData *data = [NSData dataWithContentsOfURL:[NSURL fileURLWithPath:@"/Users/zhamengjun/Desktop/Swift Programming Language.epub"]];
// 上传书籍文件
[formData appendPartWithFileData:data name:@"file" fileName:@"Swift Programming Language.epub" mimeType:@"application/epub+zip"];
// 上传图片实例
[formData appendPartWithFileData:data name:@"file" fileName:@"Snip20150715_1.png" mimeType:@"image/png"];
通过AFN设置服务器响应数据的解析方式
- 默认情况下,AFN采用以下方式解析服务器响应的数据
// 解析服务器返回的JSON数据
[AFJSONResponseSerializer serializer];
- 其它常用的解析方式
// 直接使用“服务器本来返回的数据”,不做任何解析
[AFHTTPResponseSerializer serializer];
// 解析服务器返回的XML数据
[AFXMLParserResponseSerializer serializer];
-
具体采用哪种解析方式,看客户端向服务器请求数据的类型
- 如果请求的是图片,
[AFHTTPResponseSerializer serializer];
- 如果请求的是XML数据类型
[AFXMLParserResponseSerializer serializer];
- 如果是JSON,就采用系统默认的做法
- 如果请求的是图片,
实例代码
- (void)xml
{
AFHTTPSessionManager *mgr = [AFHTTPSessionManager manager];
// responseSerializer 用来解析服务器返回的数据
// 告诉AFN,以XML形式解析服务器返回的数据
mgr.responseSerializer = [AFXMLParserResponseSerializer serializer];
NSDictionary *params = @{
@"username" : @"123",
@"pwd" : @"123",
@"type" : @"XML"
};
// 如果明确知道服务器返回数据的类型,可以直接将id改为NSXMLParser *parser
[mgr GET:@"http://www.baidu.com/login" parameters:params success:^(NSURLSessionDataTask *task, NSXMLParser *parser) {
} failure:^(NSURLSessionDataTask *task, NSError *error) {
NSLog(@"请求失败---%@", error);
}];
}