AFnetworking3.1的基本使用
听说之后AFHttpWorking版本可能会影响到苹果的审核,今天下了最新版本的AFHttpWorking,并且做了简单的封装,我这里是通过cocoapods下载了两个工具
1=AFHttpWorking 2=JSONKit 为什么要下jsonkit勒,以前json解析都使用touchjson,偶然发现资料说jsonkit效率是第三方json解析中最高的,所以今天把它也下了来下,我这里只做了AFHttpWorking 的get/post/网络判断三个方法。下面我贴代码
.h文件
|
1
2
3
4
5
6
7
8
9
10
|
#import <Foundation/Foundation.h>#import "AFDataDefine.h"#import <AFNetworking/AFNetworking.h>static NSString* const kAFAppDotNetAPIBaseURLString=@"http://www.xx.com";@interface APIClient : AFHTTPSessionManager+ (APIClient *)sharedClient;-(void)getUrl:(NSString *)URLString parameters:(id)parameters call:(void (^)( RespInfo* info))callback;-(void)postUrl:(NSString *)URLString parameters:(id)parameters call:(void (^)( RespInfo* info))callback;-(void)checkNetWorkingIsOrNoUse: (void (^)( int StateOrType))callback;@end |
.m文件
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
|
#import "APIClient.h"#import <JSONKit/JSONKit.h>#pragma mark -@implementation APIClient+ (instancetype)sharedClient { static APIClient *_sharedClient = nil; static dispatch_once_t onceToken; dispatch_once(&onceToken, ^{ _sharedClient = [[APIClient alloc] initWithBaseURL:[NSURL URLWithString:kAFAppDotNetAPIBaseURLString]]; _sharedClient.securityPolicy = [AFSecurityPolicy policyWithPinningMode:AFSSLPinningModeCertificate]; _sharedClient.requestSerializer.timeoutInterval =20; }); _sharedClient.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"text/html",@"text/plain",@"charset=UTF-8",@"Content-Type",@"application/json",nil];; return _sharedClient;}#pragma mark -/** * 网络监测(在什么网络状态) * * @callback 1 未知网络 * @callback 2 无网络 * @callback 3 蜂窝数据网 * @callback 4 WiFi网络 */-(void)checkNetWorkingIsOrNoUse: (void (^)( int StateOrType))callback{ // 创建网络监测者 [ [AFNetworkReachabilityManager sharedManager] setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status) { switch (status) { case AFNetworkReachabilityStatusUnknown: callback(1); break; case AFNetworkReachabilityStatusNotReachable: callback(2); break; case AFNetworkReachabilityStatusReachableViaWWAN: callback(3); break; case AFNetworkReachabilityStatusReachableViaWiFi: callback(4); break; default: break; } }] ; [[AFNetworkReachabilityManager sharedManager] startMonitoring];}-(void)postUrl:(NSString *)URLString parameters:(id)parameters call:(void (^)( RespInfo* info))callback{ //首先判断是否有网络 [self checkNetWorkingIsOrNoUse:^(int StateOrType) { if (StateOrType==2) { RespInfo* retobj = [[RespInfo alloc]init]; retobj.mBSuccess=NO; NSString *AlertInfo=@"请检查网络是否畅通。"; retobj.mMsg=AlertInfo; callback(retobj); } else { [self POST:URLString parameters:parameters progress:^(NSProgress * _Nonnull uploadProgress) { [[UIApplication sharedApplication] setNetworkActivityIndicatorVisible:YES]; // 开启状态栏动画 } success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) { NSString *JsonStr=[responseObject JSONString]; NSDictionary *MyDic=[JsonStr objectFromJSONString]; //申明block返回的累 RespInfo* retobj = [[RespInfo alloc]init]; //判断返回是否成功 NSString *IsOrNoSuccess=[MyDic objectForKey:@"Success"]; if ([IsOrNoSuccess intValue]==1) { retobj.mBSuccess=YES; //这里判断返回类型,如果为0不去取mObject的值,否则要取 int JudgeInt=[[MyDic objectForKey:@"ControlType"]intValue]; if (JudgeInt==0) {//只取列表值 NSString *DataListArrayStr=[MyDic objectForKey:@"Rows"]; retobj.listData=[DataListArrayStr objectFromJSONString]; } else if(JudgeInt==1)//字取附加字典值 { NSString *addicationDic=[MyDic objectForKey:@"AddicationDictionary"]; retobj.mObjectDictionary=[addicationDic objectFromJSONString]; } else if(JudgeInt==2)//两个都取 { NSString *DataListArrayStr=[MyDic objectForKey:@"Rows"]; retobj.listData=[DataListArrayStr objectFromJSONString]; NSString *addicationDic=[MyDic objectForKey:@"AddicationDictionary"]; retobj.mObjectDictionary=[addicationDic objectFromJSONString]; } //返回的公用提示消息 NSString *AlertInfo=[MyDic objectForKey:@"Msg"]; retobj.mMsg=AlertInfo; } else { retobj.mBSuccess=NO; NSString *AlertInfo=[MyDic objectForKey:@"Msg"]; retobj.mMsg=AlertInfo; } callback(retobj); } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) { RespInfo* retobj = [[RespInfo alloc]init]; retobj.mBSuccess=NO; retobj.mMsg=error.domain; }]; } }]; }-(void)getUrl:(NSString *)URLString parameters:(id)parameters call:(void (^)( RespInfo* info))callback{ //首先判断是否有网络 [self checkNetWorkingIsOrNoUse:^(int StateOrType) { if (StateOrType==2) { RespInfo* retobj = [[RespInfo alloc]init]; retobj.mBSuccess=NO; NSString *AlertInfo=@"请检查网络是否畅通。"; retobj.mMsg=AlertInfo; callback(retobj); } else { [self GET:URLString parameters:parameters progress:^(NSProgress * _Nonnull downloadProgress) { [[UIApplication sharedApplication] setNetworkActivityIndicatorVisible:YES]; // 开启状态栏动画 } success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) { [[UIApplication sharedApplication] setNetworkActivityIndicatorVisible:NO]; NSString *JsonStr=[responseObject JSONString]; NSDictionary *MyDic=[JsonStr objectFromJSONString]; //申明block返回的累 RespInfo* retobj = [[RespInfo alloc]init]; //判断返回是否成功 NSString *IsOrNoSuccess=[MyDic objectForKey:@"Success"]; if ([IsOrNoSuccess intValue]==1) { retobj.mBSuccess=YES; //这里判断返回类型,如果为0不去取mObject的值,否则要取 int JudgeInt=[[MyDic objectForKey:@"ControlType"]intValue]; if (JudgeInt==0) {//只取列表值 NSString *DataListArrayStr=[MyDic objectForKey:@"Rows"]; retobj.listData=[DataListArrayStr objectFromJSONString]; } else if(JudgeInt==1)//字取附加字典值 { NSString *addicationDic=[MyDic objectForKey:@"AddicationDictionary"]; retobj.mObjectDictionary=[addicationDic objectFromJSONString]; } else if(JudgeInt==2)//两个都取 { NSString *DataListArrayStr=[MyDic objectForKey:@"Rows"]; retobj.listData=[DataListArrayStr objectFromJSONString]; NSString *addicationDic=[MyDic objectForKey:@"AddicationDictionary"]; retobj.mObjectDictionary=[addicationDic objectFromJSONString]; } //返回的公用提示消息 NSString *AlertInfo=[MyDic objectForKey:@"Msg"]; retobj.mMsg=AlertInfo; } else { retobj.mBSuccess=NO; NSString *AlertInfo=[MyDic objectForKey:@"Msg"]; retobj.mMsg=AlertInfo; } callback(retobj); } failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) { RespInfo* retobj = [[RespInfo alloc]init]; retobj.mBSuccess=NO; retobj.mMsg=error.domain; }]; } }]; }// @end |
block返回的类
|
1
2
3
4
5
6
7
8
9
10
11
|
#pragma mark - RespInfo 外层封装数据@interface RespInfo : AFDataDefine@property (nonatomic,strong) NSArray *listData; //列表数据@property(nonatomic,strong)NSDictionary *mObjectDictionary;//附带字典@property (nonatomic,strong) NSString* mMsg; //提示消息@property (nonatomic,assign) BOOL mBSuccess; //返回状态,成功失败,判断这个+(RespInfo *)infoWithError:(NSError *)error;+(RespInfo *)infoWithErrorMessage:(NSString *)errMsg;@end |
调用

1 #import "ViewController.h"
2 #import "APIClient.h"
3
4 @interface ViewController ()
5
6 @end
7
8 @implementation ViewController
9
10 - (void)viewDidLoad {
11 [super viewDidLoad];
12 // Do any additional setup after loading the view, typically from a nib.
13 NSUUID *iD=[[NSUUID alloc]init];
14 NSString *UUIDvALUE=[iD UUIDString];
15
16
17
18
19
20 NSDictionary *Dic=[[NSDictionary alloc]initWithObjectsAndKeys:@"0",@"dataType", nil];
21
22 [[APIClient sharedClient] getUrl:@"/Mobile/Jmfww.asmx/JmfwwCommunity" parameters:Dic call:^(RespInfo *info) {
23 if ([info mBSuccess]) {
24
25
26
27
28 }
29 }];
30
31 }
32
33 - (void)didReceiveMemoryWarning {
34 [super didReceiveMemoryWarning];
35 // Dispose of any resources that can be recreated.
36 }
AFnetworking3.1的基本使用的更多相关文章
- IOS 网络浅析-(十一 三方 AFNetworking3.0简介)
AFNetworking3.0是目前最新的版本,本来打算介绍一下2.6,但是想想2.6名不久矣,就决定不介绍了,有兴趣的小伙伴可以上网查一查.下面我就开始进入正题了. 目前使用人数最多的第三方网络库, ...
- iOS 适配https(AFNetworking3.0为例)
众所周知,苹果有言,从2017年开始,将屏蔽http的资源,强推https楼主正好近日将http转为https,给还没动手的朋友分享一二 1.准备证书 首先找后台要一个证书(SSL证书,一般你跟后台说 ...
- AFNetworking3.1.0检查网络状态
我们知道AFNetworking3.0版本中,弃用了AFHTTPRequestOperationManager.那么进行网络判断的时候就需要使用 AFNetworkReachabilityManage ...
- 网络婚礼之AFNetWorking3.0
目前使用人数最多的第三方网络库,没有之一.从开始的NSURLConnection到现在的NSURLSession,它都一直保持着与苹果的步调一致,而由它也衍生出大量的相关第三方网络功能库,不仅仅因为他 ...
- iOS- 利用AFNetworking3.0+(最新AFN) - 实现文件断点下载
官方建议AFN的使用方法 0.导入框架准备工作 •1. 将AFNetworking3.0+框架程序拖拽进项目 •2. 或使用Cocopod 导入AFNetworking3.0+ •3. ...
- iOS开发--基于AFNetWorking3.0的图片缓存分析
图片在APP中占有重要的角色,对图片做好缓存是重要的一项工作.[TOC] 理论 不喜欢理论的可以直接跳到下面的Demo实践部分 缓存介绍 缓存按照保存位置可以分为两类:内存缓存.硬盘缓存(FMDB.C ...
- AFNetworking3.0+MBProgressHUD二次封装,一句话搞定网络提示
对AFNetworking3.0+MBProgressHUD的二次封装,使用更方便,适用性非常强: 一句话搞定网络提示: 再也不用担心网络库更新后,工程要修改很多地方了!网络库更新了只需要更新这个封装 ...
- 基于AFNetworking3.0网络封装
概述 对于开发人员来说,学习网络层知识是必备的,任何一款App的开发,都需要到网络请求接口.很多朋友都还在使用原生的NSURLConnection一行一行地写,代码到处是,这样维护起来更困难了. 对于 ...
- iOS_SN_基于AFNetworking3.0网络封装
转发文章,原地址:http://www.henishuo.com/base-on-afnetworking3-0-wrapper/?utm_source=tuicool&utm_medium= ...
- AFNetworking3.0的基本使用方法
前一段时间在做项目的时候发现AFNetworking3.0已经被大众所接受,所以以后肯定会有很多程序猿朋友必须了解和转移至3.0了,这是我这段时间使用和学习总结出来的一些常用的知识点,希望对大家有用. ...
随机推荐
- UIScrollView解决无法触发手势
//创建一个分类 //.h #import <UIKit/UIKit.h> @interface UIScrollView (Touch) - (void)touchesBegan:(NS ...
- 用nodejs搭建一个简单的服务器
使用nodejs搭建一个简单的服务器 nodejs优点:性能高(读写文件) 数据操作能力强 官网:www.nodejs.org 验证是否安装成功:cmd命令行中输入node -v 如果显示版本号表示安 ...
- http协议(五)web服务器
1.http1.1规范允许一台http服务器搭建多个web站点... 比如提供web托管服务的供应商,可以用一台服务器为多为客户服务,也可以以每位客户持有的域名运行各自不同的网站,这里利用了虚拟服务器 ...
- 苹果IOS开发者账号总结--发布应用APP时team name是否可以随意写?
个人账号(Individual): 费用99美金一年, 该账号在App Store销售者只能显示个人的ID,比如zhitian zhang,单人使用.个人账号只能有一个开发者.100个苹果的iOS设备 ...
- 01Spring_基本jia包的导入andSpring的整体架构and怎么加入日志功能
1.什么是Spring : v\:* {behavior:url(#default#VML);} o\:* {behavior:url(#default#VML);} w\:* {behavior:u ...
- SQL Server DB Type and CLR Type
这段时间学习SQL Server CLR编程,但是SQL CLR编程,里面所使用的数据类型为CLE TYPE,它多少与 Db TYPE有些区别,在网上找到一个列表http://geekswithblo ...
- Windows 8.1 新增控件之 CommandBar
上一篇为大家介绍了AppBar 的相关内容,本篇继续介绍CommandBar 的使用方法.与AppBar 相比而言,CommandBar 在开发使用方面较为单一,在按键布局上分为主控区(Primary ...
- FastReport 隐藏matrix的列如何实现
fastReport在处理 行列都是浮动的时候非常好用. 但是也有一些不太直观的东西.比如说要设置生成结果的某行某列. 修改字体颜色背景色,隐藏,设置行高,设置列宽等等. 可以在 matrix的aft ...
- Nodejs生态圈的TypeScript+React
基于Nodejs生态圈的TypeScript+React开发入门教程 基于Nodejs生态圈的TypeScript+React开发入门教程 概述 本教程旨在为基于Nodejs npm生态圈的前端程 ...
- 求连续最大子序列积 - leetcode. 152 Maximum Product Subarray
题目链接:Maximum Product Subarray solutions同步在github 题目很简单,给一个数组,求一个连续的子数组,使得数组元素之积最大.这是求连续最大子序列和的加强版,我们 ...