一、前言
我们在iOS开发的过程中,往往后端和前端都是并行的,当后端的接口没有完善的时候就会影响到我们的开发,而我也在我编程的过程中也经历过很多方法去制造假数据,下面我就一一说一下吧。
二、方法
下面我们以如下的JSON字段进行一下说明
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
{
"code"
:
0
,
"message"
:
"成功"
,
"data"
: {
"website"
:
"https://www.ianisme.com"
,
"list"
: [
{
"day"
:
"30"
,
"month"
:
"10"
,
"year"
:
"2017"
}
]
}
}
|
2.1 Dictionary假数据
这种方法应该说是最不建议使用的方法了。假设我们工程中使用的是JSModel进行Model层转换的。
我们需要这样写一个NSDictionary
如图所示我们就可以这样去写假数据了。这种方法是每次都要去修改和编辑大量代码,并且关于网络请求的代码还测试不了,不推荐使用。
2.2 搭建后台假数据
我们可以本地用搭建一个网站环境或者使用远程服务器去请求。
我会保存一个json文件,然后用一个php文件去调用。
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
|
<!--?php
header(
"Content-type: text/html; charset=utf-8"
);
$test = $_POST[
"s"
];
$json_string = file_get_contents($test . &#
39
;.json&#
39
;);
echo $json_string;</pre--><p style=
"text-align: center;"
><img src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception1.png"
_src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception1.png"
></p><p style=
"text-align: center;"
><img src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception2.png"
_src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception2.png"
></p><p>这种情况下,我们可以直接把app端的网络请求代码全部写好,就相当于模仿后台的接口一样,到时候切换后台接口我们只需要更换下接口地址就行了。</p><p><strong>
2.3
APP端修改服务器数据</strong></p><p>这里我们以 AFNetworking2.x 为例使用 NSURLProtocol 拦截 HTTP 请求。</p><p>创建NSURLProtocol的一个子类,重写里面的startLoading方法。</p><pre
class
=
"brush:as3;toolbar:false"
>- (
void
)startLoading
{
NSMutableURLRequest *mutableReqeust = [[self request] mutableCopy];
[NSURLProtocol setProperty:@YES forKey:hasInitKey inRequest:mutableReqeust];
if
([mutableReqeust.URL.description containsString:@
"api.ianisme.com"
]) {
NSDictionary *dic = @{
@
"code"
: @
0
,
@
"message"
: @
"成功"
,
@
"data"
: @{
@
"website"
: @
"https://www.ianisme.com"
,
@
"list"
: @[
@{
@
"day"
: @
"30"
,
@
"month"
: @
"10"
,
@
"year"
: @
"2017"
}
]
}
};
NSData *tempData = [self toJSONData:dic];
NSString *jsonString = [[NSString alloc] initWithData:tempData
encoding:NSUTF8StringEncoding];
NSData *data = [jsonString dataUsingEncoding:NSUTF8StringEncoding];
NSURLResponse *response = [[NSURLResponse alloc] initWithURL:mutableReqeust.URL
MIMEType:@
"text/html"
expectedContentLength:data.length
textEncodingName:nil];
[self.client URLProtocol:self
didReceiveResponse:response
cacheStoragePolicy:NSURLCacheStorageNotAllowed];
[self.client URLProtocol:self didLoadData:data];
[self.client URLProtocolDidFinishLoading:self];
}
else
{
self.myConnection = [NSURLConnection connectionWithRequest:mutableReqeust delegate:self];
}
}</pre><p style=
"text-align: center;"
><img src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception3.png"
_src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception3.png"
></p><p>此方法我们可以把相关网络请求写好,然后本地代码拦截后台的网络请求,用假数据修改就行了。以上只是一个原理的演示,实际开发,推荐使用强大的开源库OHHTTPStubs, 他可以伪造的网络数据和模拟的缓慢网络来进行调试。</p><p>传送门-><a href=
"https://github.com/AliSoftware/OHHTTPStubs"
target=
"_blank"
_href=
"https://github.com/AliSoftware/OHHTTPStubs"
>OHHTTPStubs</a></p><p><strong>
2.4
代理拦截网络请求</strong></p><p>这个是我比较推荐的一个方案,不需要修改app端代码。一切无损对接后台。</p><p>这就是利用代理软件的 Map Local 功能,将请求转换为请求电脑本地的静态json文件。</p><p>我们以Charles为例,我们把本地的接口写好之后,我们使用Charles抓一下这个接口的请求,此时肯定是失败的。</p><p>如图:</p><p style=
"text-align: center;"
><img src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception4-768x343.png"
_src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception4-768x343.png"
></p><p>我们去 Map Local 指向电脑中的一个json文件。</p><p>如图:</p><p style=
"text-align: center;"
><img src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception5.png"
_src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception5.png"
></p><p style=
"text-align: center;"
><img src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception6.png"
_src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception6.png"
></p><p style=
"text-align: center;"
><img src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception7.png"
_src=
"https://www.ianisme.com/wp-content/uploads/2017/11/networkInterception7.png"
></p><p>这样我们就将此接口指向了电脑本地的一个json文件,我们可以用此方法,将所有的接口都分别指向本地的各自的 json 文件,当后台接口完毕后,我们就可以关闭 Map Local 无缝衔接到真正的后台。</p><p>本文涉及到的部分代码 -> <a href=
"https://github.com/ianisme/NetworkInterception"
target=
"_blank"
_href=
"https://github.com/ianisme/NetworkInterception"
>点我下载</a></p><p><span style=
"font-size: 24px;"
><strong>三、总结</strong></span></p><p>以上四个方法,我的推荐程度是由小到大的。我认为最好不要去动APP的代码,所以我推荐第四种,赶快去尝试一下吧!你用的哪种呢?欢迎留言交流。</p><p>参考与延伸:</p><ul
class
=
" list-paddingleft-2"
><li><p><a href=
"https://draveness.me/intercept"
target=
"_blank"
_href=
"https://draveness.me/intercept"
>《iOS 开发中使用 NSURLProtocol 拦截 HTTP 请求》</a></p></li><li><p><a href=
"https://draveness.me/http-mock"
target=
"_blank"
_href=
"https://draveness.me/http-mock"
>《如何进行 HTTP Mock(iOS)》</a></p></li><li><p><a href=
"http://blog.devtang.com/2015/11/14/charles-introduction/"
target=
"_blank"
_href=
"http://blog.devtang.com/2015/11/14/charles-introduction/"
>《Charles 从入门到精通》</a></p></li><li><p><a href=
"https://www.ianisme.com/ios/2502.html"
target=
"_blank"
_href=
"https://www.ianisme.com/ios/2502.html"
>《关于Charles抓HTTPS包的tips》</a></p></li><li><p><a href=
"http://blog.csdn.net/colorapp/article/details/47007431"
target=
"_blank"
_href=
"http://blog.csdn.net/colorapp/article/details/47007431"
>《iOS单元测试:Specta + Expecta + OCMock + OHHTTPStubs + KIF》</a></p></li></ul>
|