听说之后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 NSStringconst  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的基本使用的更多相关文章

  1. IOS 网络浅析-(十一 三方 AFNetworking3.0简介)

    AFNetworking3.0是目前最新的版本,本来打算介绍一下2.6,但是想想2.6名不久矣,就决定不介绍了,有兴趣的小伙伴可以上网查一查.下面我就开始进入正题了. 目前使用人数最多的第三方网络库, ...

  2. iOS 适配https(AFNetworking3.0为例)

    众所周知,苹果有言,从2017年开始,将屏蔽http的资源,强推https楼主正好近日将http转为https,给还没动手的朋友分享一二 1.准备证书 首先找后台要一个证书(SSL证书,一般你跟后台说 ...

  3. AFNetworking3.1.0检查网络状态

    我们知道AFNetworking3.0版本中,弃用了AFHTTPRequestOperationManager.那么进行网络判断的时候就需要使用 AFNetworkReachabilityManage ...

  4. 网络婚礼之AFNetWorking3.0

    目前使用人数最多的第三方网络库,没有之一.从开始的NSURLConnection到现在的NSURLSession,它都一直保持着与苹果的步调一致,而由它也衍生出大量的相关第三方网络功能库,不仅仅因为他 ...

  5. iOS- 利用AFNetworking3.0+(最新AFN) - 实现文件断点下载

    官方建议AFN的使用方法   0.导入框架准备工作 •1. 将AFNetworking3.0+框架程序拖拽进项目   •2. 或使用Cocopod 导入AFNetworking3.0+   •3.   ...

  6. iOS开发--基于AFNetWorking3.0的图片缓存分析

    图片在APP中占有重要的角色,对图片做好缓存是重要的一项工作.[TOC] 理论 不喜欢理论的可以直接跳到下面的Demo实践部分 缓存介绍 缓存按照保存位置可以分为两类:内存缓存.硬盘缓存(FMDB.C ...

  7. AFNetworking3.0+MBProgressHUD二次封装,一句话搞定网络提示

    对AFNetworking3.0+MBProgressHUD的二次封装,使用更方便,适用性非常强: 一句话搞定网络提示: 再也不用担心网络库更新后,工程要修改很多地方了!网络库更新了只需要更新这个封装 ...

  8. 基于AFNetworking3.0网络封装

    概述 对于开发人员来说,学习网络层知识是必备的,任何一款App的开发,都需要到网络请求接口.很多朋友都还在使用原生的NSURLConnection一行一行地写,代码到处是,这样维护起来更困难了. 对于 ...

  9. iOS_SN_基于AFNetworking3.0网络封装

    转发文章,原地址:http://www.henishuo.com/base-on-afnetworking3-0-wrapper/?utm_source=tuicool&utm_medium= ...

  10. AFNetworking3.0的基本使用方法

    前一段时间在做项目的时候发现AFNetworking3.0已经被大众所接受,所以以后肯定会有很多程序猿朋友必须了解和转移至3.0了,这是我这段时间使用和学习总结出来的一些常用的知识点,希望对大家有用. ...

随机推荐

  1. 如何查看文件是dos格式还是unix格式的?

    一.背景 由于windows和linux对换行的标识不一样,不同系统的代码传递导致代码格式的改变中可能会带来程序无法正常编译通过的问题.因此根据一些编译的错误提示,可以定位到是文件格式的问题,要对程序 ...

  2. sql将同一个表中的两列Int数据相加,有些数据是空的

    不能这样加! 有些数据为null吧,null+任何值=null 如这句话就不行 update HY_MYGGCYSWCQKB set HY_MYGGCYSWCQKB.Sj_By_Sr=HY_MYGGC ...

  3. AlwaysOn--Backup Preference

    AlwaysOn group的一个新特性是允许在secondary replica进行backup,将backup的负载从primary replica上移除去. 并且提供了Backup prefer ...

  4. Linux操作系统下三种配置环境变量的方法

    现在使用linux的朋友越来越多了,在linux下做开发首先就是需要配置环境变量,下面以配置java环境变量为例介绍三种配置环境变量的方法. 1.修改/etc/profile文件 如果你的计算机仅仅作 ...

  5. [转] EJB 3和Spring技术体系比较

    最近在学习EJB 3,对于SSH与EJB3,一直不太明白“即生瑜,何生亮?”,今天无意看到一篇旧文,比较系统的对比了这二种技术架构,转载于此: 原文出处:http://www.51cto.com/sp ...

  6. unix环境高级编程基础知识之第一篇

    陆陆续续看完了圣经第一章,熟悉了unix的整个编程流程,c语言的用处在这里得到伸张. 从unix的体系结构,原来操作系统包括内核及一些其他软件,我们常常误称为linux内核为操作系统,这俨然成为一种共 ...

  7. 阿里云Ubuntu 14.04 + Nginx + let's encrypt 搭建https访问

    参考页面: https://certbot.eff.org/#ubuntutrusty-nginx http://bbs.qcloud.com/thread-12059-1-1.html http:/ ...

  8. 常用hadoop web

    http://localhost:50070 Hadoop服务 http://localhost:8088/ 集群中的所有应用程序 http://localhost:16010 hbase

  9. C#链接阿里云KVStore

    KVStore的简单介绍 阿里云KVStore兼容Redis.因为KVStore就相当于Redis的服务器端,我们代码只是当作客户端,链接上服务器端就行了,阿里云的KVStore详情文档见,https ...

  10. 前端框架——AmazeUI学习

    AmazeUI官网: http://amazeui.org/ 前后台模板下载:链接:链接:http://pan.baidu.com/s/1c2uVfk0 密码:zuva 十大前端框架参考链接:http ...