众所周知,app的数据一般都来源于服务器.但是在服务器代码还没写好的情况下,就需要我们客户端等了.为了节省时间,提高开发效率.这个时候就需要我们客户端自己模拟后台返回的数据了. 提前写好业务逻辑,等后台部署成功,就可以套用了.
一、自己在本地写假数据
优点:即写即用,没有学习难度
缺点:需要在本地修改大量代码,有的时候测试代码,忘记删除,导致项目出现问题
二、修改服务器返回的数据
优点:不需要在本地修改大量代码,直接修改更上层的服务器数据,使项目的代码精简,更贴合业务需求
缺点:需要用到其它语言,有一定的学习成本
三、搭建服务器环境
参考 https://blog.csdn.net/w956443578w/article/details/124073146
四、代码部分
1、iOS代码
AFHTTPSessionManager *manager = [AFHTTPSessionManager manager];
manager.responseSerializer.acceptableContentTypes = [NSSet setWithObjects:@"application/json",@"text/json", @"text/plain", @"text/html", nil];
NSString *strListUrl = [NSString stringWithFormat:@"http://www.kuaidi100.com/query?type=yuantong&postid=11111111111"];
[manager POST:strListUrl parameters:nil headers:nil progress:^(NSProgress * _Nonnull uploadProgress) {
} success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
NSLog(@"原始数据---------------->%@",responseObject);
[manager POST:@"http://localhost:3000/tars" parameters:@{@"cmdname":strListUrl,@"data": [responseObject mj_JSONString]} headers:nil progress:nil success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
NSLog(@"修改后的数据---------------->%@",responseObject);
} failure:nil];
} failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
}];
2、服务器代码
// 创建一个程序实例
const app = express()
const bodyParser=require("body-parser")
var jsonParser = bodyParser.json()
var urlencodedParser = bodyParser.urlencoded({ extended: false })
app.use(jsonParser)
app.use(urlencodedParser)
// 设置端口
const port = process.env.PORT || 3000;
app.get('/',(req,res)=>{
res.send("通过express实现的简单服务器");
})
// http://localhost:3000/tars
app.post('/tars',(req,res) => {
let params = req.body
console.log('传入的参数',params)
let originData = params.data
let cmdname = params.cmdname
console.log('原始数据',originData)
let dict = JSON.parse(originData)
if (cmdname === 'http://www.kuaidi100.com/query?type=yuantong&postid=11111111111') { //需要拦截
console.log('需要拦截')
//返回自己定制的数据
let fakeData = {'login_id':'90003863','uni_token':'a82abde55eb22b7aac7aca2ae53de00a5269582240ce6ea83fe337a22358343d','third_token':'3','ask_bind_flag':'1','ask_bind_tips':'为了账户安全,请重新绑定资金账号','tel_no_verify_token':'a82abde55eb22b7aac7aca2ae53de00a5269582240ce6ea83fe337a22358343d'}
res.json(fakeData)
}else { // 不需要拦截
console.log('不需要拦截')
res.json(dict)
}
})
app.listen(port,()=>{
console.log(`serve susscess, localhost:${port}`);
})
五、实操
1、新建一个js文件,testNetWork.js , 输入上面的服务器代码, 并保存
2、打开终端进入testNetWork.js 所在目录, 输入 nodetestNetWork.js
972FA83BF1736132F12B67A124E6CE87.pngB07A9EF97058A25D9E242B9C1154FB8F.png
3、在iOS项目里,网络请求的模块改成上面的iOS代码
六、结果
2022-09-21 15:09:34.175287+0800 ScPrice[44883:739710] 原始数据---------------->{
com = yuantong;
condition = 00;
data = (
{
context = "\U79bb\U5f00\U3010\U957f\U6c40\U5146\U5f81\U90ae\U653f\U63fd\U6295\U3011,\U4e0b\U4e00\U7ad9\U3010\U957f\U6c40\U5146\U5f81\U90ae\U653f\U63fd\U6295\U3011";
ftime = "2022-06-16 11:08:32";
location = "";
time = "2022-06-16 11:08:32";
},
{
context = "\U5230\U8fbe\U3010\U9f99\U5ca9\U5e02\U90ae\U4ef6\U5904\U7406\U8f66\U95f4\U3011";
ftime = "2022-06-16 05:02:43";
location = "";
time = "2022-06-16 05:02:43";
},
{
context = "\U79bb\U5f00\U3010\U53a6\U95e8\U5e02\U5305\U4ef6\U8f66\U95f4\U3011,\U4e0b\U4e00\U7ad9\U3010\U9f99\U5ca9\U5e02\U90ae\U4ef6\U5904\U7406\U8f66\U95f4\U3011\Uff08\U7ecf\U8f6c\Uff09";
ftime = "2022-06-16 01:55:23";
location = "";
time = "2022-06-16 01:55:23";
},
{
2022-09-21 15:09:39.835338+0800 ScPrice[44883:739710] 修改后的数据---------------->{
"ask_bind_flag" = 1;
"ask_bind_tips" = "\U4e2d\U91d1\U8d22\U5bcc\U8fdb\U884c\U4e86\U8d26\U6237\U7cfb\U7edf\U5b89\U5168\U5347\U7ea7\Uff0c\U4e3a\U4e86\U8d26\U6237\U5b89\U5168\Uff0c\U8bf7\U91cd\U65b0\U7ed1\U5b9a\U8d44\U91d1\U8d26\U53f7";
"login_id" = 90003863;
"tel_no_verify_token" = a82abde55eb22b7aac7aca2ae53de00a5269582240ce6ea83fe337a22358343d;
"third_token" = 3;
"uni_token" = a82abde55eb22b7aac7aca2ae53de00a5269582240ce6ea83fe337a22358343d;
}
可以看到数据确实是改成了我们需要的了
网友评论