Crates.io | api-resp |
lib.rs | api-resp |
version | 0.1.3 |
source | src |
created_at | 2023-01-19 09:17:28.061138 |
updated_at | 2023-01-27 03:49:11.871345 |
description | 为远程/异步调用API的返回结果,定义通用的封装结构和基本方法,返回的数据结构为json字符串。 |
homepage | https://github.com/t1000ln/api-resp |
repository | https://github.com/t1000ln/api-resp |
max_upload_size | |
id | 762429 |
size | 12,063 |
该模块为远程/异步调用API的返回结果,定义通用的封装结构和基本方法。
返回的数据是JSON
格式的,结构示例:
{
"success": true,
"code": 0,
"message": "",
"data": []
}
四个属性简要说明:
success
表示调用是否成功。
code
成功为0
,失败为非0
的整数值。
message
在失败时提供简要的说明信息。
data
返回的业务数据,也是JSON
格式。
用法示例:
#[cfg(test)]
mod tests {
use serde_json::json;
use super::*;
#[derive(Debug, Serialize, Deserialize)]
struct PingPang {
color: String,
weight: f64,
}
#[test]
fn test_resp() {
// 成功结果,没有业务数据。
let suc_json = ApiResp::suc().to_json();
println!("suc_json: {}", suc_json);
let orig_suc: ApiResp = serde_json::from_str(suc_json.as_str()).unwrap();
assert!(orig_suc.is_success());
// 成功结果,带有业务数据。
let vals = vec![
PingPang {color: "white".to_string(), weight: 10.0},
PingPang {color: "yellow".to_string(), weight: 11.5},
];
let suc_data = ApiResp::success(json!(vals)).to_json();
println!("suc_data: {}", suc_data);
let orig_suc_data: ApiResp = serde_json::from_str(suc_data.as_str()).unwrap();
assert!(orig_suc_data.is_success());
// 失败结果。
let fail_json = ApiResp::error(-1, String::from("交易出错了")).to_json();
println!("fail_json: {}", fail_json);
let orig_fail: ApiResp = serde_json::from_str(fail_json.as_str()).unwrap();
assert!(!orig_fail.is_success());
}
}
执行上面的测试方法将打输出类似下面的信息:
suc_json:
{"success":true,"code":0,"message":"","data":null}
suc_data:
{"success":true,"code":0,"message":"","data":[{"color":"white","weight":10.0},{"color":"yellow","weight":11.5}]}
fail_json:
{"success":false,"code":-1,"message":"交易出错了","data":null}