对于开发人员来说,学习网络层知识是必备的,任何一款App
的开发,都需要到网络请求接口。很多朋友都还在使用原生的NSURLConnection
一行一行地写,代码到处是,这样维护起来更困难了。
对于使用AFNetworking
的朋友来说,很多朋友都是直接调用AFNetworking
的API
,这样不太好,无法做到全工程统一配置。
最好的方式就是对网络层再封装一层,全工程不允许直接使用AFNetworking
的API
,必须调用我们自己封装的一层,如此一来,任何网络配置都可以在这一层里配置好,使用的人无须知道里面在干嘛,只管调用就可以了。
本篇讲解的是基于AFNetworkging2.5.2版本的网络封装,支持iOS6.若不需要支持iOS6,可选择基于AFNetworking3.0的网络封装:http://www.henishuo.com/base-on-afnetworking3-0-wrapper/
应用开发过程中,所使用类型通常是GET
、POST
及上传图片。因此,这里只是对这几种类型提供API
。
这里提供了两个GET
请求的API
,需要一般情况下GET
请求都是直接写一个完整的URL
,但是有时候为了参数可读性更强,改成传一个字典过来更容易阅读。
HYBResponseSuccess
是响应成功的回调,返回的是字典,外部再转换成模型就可以了。
HYBResponseFail
是响应失败的回调,只有一个NSError
对象,外部可接收处理。
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
|
/*!
* @author 黄仪标, 15-11-15 13:11:50
*
* GET请求接口,若不指定baseurl,可传完整的url
*
* @param url 接口路径,如/path/getArticleList?categoryid=1
* @param success 接口成功请求到数据的回调
* @param fail 接口请求数据失败的回调
*
* @return 返回的对象中有可取消请求的API
*/
+
(
HYBRequestOperation
*
)
getWithUrl
:
(
NSString
*
)
url
success
:
(
HYBResponseSuccess
)
success
fail
:
(
HYBResponseFail
)
fail
;
/*!
* @author 黄仪标, 15-11-15 13:11:50
*
* GET请求接口,若不指定baseurl,可传完整的url
*
* @param url 接口路径,如/path/getArticleList
* @param params 接口中所需要的拼接参数,如@{"categoryid" : @(12)}
* @param success 接口成功请求到数据的回调
* @param fail 接口请求数据失败的回调
*
* @return 返回的对象中有可取消请求的API
*/
+
(
HYBRequestOperation
*
)
getWithUrl
:
(
NSString
*
)
url
params
:
(
NSDictionary
*
)
params
success
:
(
HYBResponseSuccess
)
success
fail
:
(
HYBResponseFail
)
fail
;
|
对于POST
请求类型的接口,只有一个,看注释就可以明白如何使用了。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
/*!
* @author 黄仪标, 15-11-15 13:11:50
*
* POST请求接口,若不指定baseurl,可传完整的url
*
* @param url 接口路径,如/path/getArticleList
* @param params 接口中所需的参数,如@{"categoryid" : @(12)}
* @param success 接口成功请求到数据的回调
* @param fail 接口请求数据失败的回调
*
* @return 返回的对象中有可取消请求的API
*/
+
(
HYBRequestOperation
*
)
postWithUrl
:
(
NSString
*
)
url
params
:
(
NSDictionary
*
)
params
success
:
(
HYBResponseSuccess
)
success
fail
:
(
HYBResponseFail
)
fail
;
|
接口一次只能上传一张图片,通常也是这么处理的。这里是以文件流的形式来上传的哦。其中,mineType
为image/jpeg
。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
/*!
* @author 黄仪标, 15-11-15 13:11:39
*
* 图片上传接口,若不指定baseurl,可传完整的url
*
* @param image 图片对象
* @param url 上传图片的接口路径,如/path/images/
* @param filename 给图片起一个名字,默认为当前日期时间,格式为"yyyyMMddHHmmss",后缀为`jpg`
* @param name 与指定的图片相关联的名称,这是由后端写接口的人指定的,如imagefiles
* @param success 上传成功的回调
* @param fail 上传失败的回调
*
* @return 返回类型有取消请求的api
*/
+
(
HYBRequestOperation
*
)
uploadWithImage
:
(
UIImage
*
)
image
url
:
(
NSString
*
)
url
filename
:
(
NSString
*
)
filename
name
:
(
NSString
*
)
name
success
:
(
HYBResponseSuccess
)
success
fail
:
(
HYBResponseFail
)
fail
;
|
这里还提供了两个公共接口,一个是用于设置或者更新网络接口的基础URL,一个是获取当前设置使用的网络接口基础URL。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
/*!
* @author 黄仪标, 15-11-15 13:11:45
*
* 用于指定网络请求接口的基础url,如:
* http://henishuo.com或者http://101.200.209.244
* 通常在AppDelegate中启动时就设置一次就可以了。如果接口有来源
* 于多个服务器,可以调用更新
*
* @param baseUrl 网络接口的基础url
*/
+
(
void
)
updateBaseUrl
:
(
NSString
*
)
baseUrl
;
/*!
* @author 黄仪标, 15-11-15 13:11:06
*
* 对外公开可获取当前所设置的网络接口基础url
*
* @return 当前基础url
*/
+
(
NSString
*
)
baseUrl
;
|
通常每家公司的接口都会设置公共的请求头参数,以代表是公司的接口。默认已经配置了可接收的类型,但是如果需要额外配置,可通过调用此api
来添加:
1
2
3
4
5
6
7
8
9
10
|
/*!
* @author 黄仪标, 15-11-16 13:11:41
*
* 配置公共的请求头,只调用一次即可,通常放在应用启动的时候配置就可以了
*
* @param httpHeaders 只需要将与服务器商定的固定参数设置即可
*/
+
(
void
)
configCommonHttpHeaders
:
(
NSDictionary
*
)
httpHeaders
;
|
默认responseType和requestType都是JSON格式。如果不使用JSON,可以全局配置成自己希望的格式即可。若不配置,默认就是JSON。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
/*!
* @author 黄仪标, 15-12-25 15:12:38
*
* 配置返回格式,默认为JSON。若为XML或者PLIST请在全局修改一下
*
* @param responseType 响应格式
*/
+
(
void
)
configResponseType
:
(
HYBResponseType
)
responseType
;
/*!
* @author 黄仪标, 15-12-25 15:12:45
*
* 配置请求格式,默认为JSON。如果要求传XML或者PLIST,请在全局配置一下
*
* @param requestType 请求格式
*/
+
(
void
)
configRequestType
:
(
HYBRequestType
)
requestType
;
|
考虑到网络请求接口中,有时候会有中文参数,这时候就会请求失败,因此我们要对这种类型的URL
进行编码,否则请求会失败。这里是开启或者关闭自动将URL
编码的接口,默认为NO,表示不开启。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
/*!
* @author 黄仪标, 15-11-15 14:11:40
*
* 开启或关闭接口打印信息
*
* @param isDebug 开发期,最好打开,默认是NO
*/
+
(
void
)
enableInterfaceDebug
:
(
BOOL
)
isDebug
;
/*!
* @author 黄仪标, 15-11-15 15:11:16
*
* 开启或关闭是否自动将URL使用UTF8编码,用于处理链接中有中文时无法请求的问题
*
* @param shouldAutoEncode YES or NO,默认为NO
*/
+
(
void
)
shouldAutoEncodeUrl
:
(
BOOL
)
shouldAutoEncode
;
|
对于网络请求回来的结果,如果没有一个格式化好的日志打印出来查看,就要通过断点一步步跟踪,然后打开出来看,这太麻烦。因此,这里提供了打印日志的私有API
。默认是不开启打印日志的。
1
2
3
4
5
6
7
8
9
10
|
/*!
* @author 黄仪标, 15-11-15 14:11:40
*
* 开启或关闭接口打印信息
*
* @param isDebug 开发期,最好打开,默认是NO
*/
+
(
void
)
enableInterfaceDebug
:
(
BOOL
)
isDebug
;
|
通常在AppDelegate
中应用启动的代理方法中调用设置为开启就可以了。不过是否设置为开启,当应用以发布证书打包时,都不会打印日志,因为这里做了处理,可放心使用。
1
2
3
4
5
6
7
8
9
|
// 项目打包上线都不会打印日志,因此可放心。
#ifdef DEBUG
#define HYBAppLog(s, ... ) NSLog( @"[%@:in line: %d]-->[message: %@]", [[NSString stringWithUTF8String:__FILE__] lastPathComponent], __LINE__, [NSString stringWithFormat:(s), ##__VA_ARGS__] )
#else
#define HYBAppLog(s, ... )
#endif
|