我有这样的代码:
$iterator = 0;
while (($end = $sth->fetch()) && $iterator < 2)
{
$api_arr["data"]['tc'][] = $end["tc"];
$api_arr["data"]['em'][] = $end["em"];
$api_arr["data"]['sg'][] = $end["sg"];
$iterator ++;
}
我为其他开发者创建了我的网站API。我给他们一个JSON输出。像这样:
{
-data{
tc: [
"value_tc_1",
"value_tc_2",
"value_tc_3"
],
em: [
"value_em_1",
"value_em_2",
"value_em_3"
],
sg: [
"value_sg_1",
"value_sg_2",
"value_sg_3"
]
}
}
当前输出: (当没有任何行$sth->rowCount() == ''
时)
[]
我想要的是什么: (当没有任何行$sth->rowCount() == ''
时)
{
-data{
tc: [false],
em: [false],
sg: [false]
}
}
嗯,我怎么能这样做?
作为咨询:当没有结果时,是否必须将false
设置为数组的值?我从未有过创建API的经验。我想根据一些类似的API (来自其他网站)设置false
。
实际上我想向其他开发者提供一个标准并且可用。那么,我做的是API吗?其他开发人员可以使用它吗?
我不知道,也许我需要的是这个:
{
-data{
tc: false,
em: false,
sg: false
}
}
一般来说,我需要知道什么? {事先感谢:)
}
我尝试了什么:我认为这样的事情会有用,但实际上我不知道应该如何使用它:
array_fill_keys(array_keys($api_arr['data']), "false");
答案 0 :(得分:3)
使用空值启动数组:
$iterator = 0;
$api_arr = [
'data'=>
[
'tc'=>[],
'em'=>[],
'sg'=>[]
]
];
while (($end = $sth->fetch()) && $iterator < 2)
{
$api_arr["data"]['tc'][] = $end["tc"];
$api_arr["data"]['em'][] = $end["em"];
$api_arr["data"]['sg'][] = $end["sg"];
$iterator ++;
}
如果数据库中没有结果,则结果为:
{
data{
tc: [],
em: [],
sg: []
}
}
对于期望包含数组的数据结构的API使用者而言,这将是一致的。可能整个结构都可以重构,但一致性是一个好的开始
要展开"the whole structure can be refactored"
部分,查看数据,似乎值在逻辑上分组在数据库中(一行包含相关的tc
,em
和{{1}但是你没有明确的理由将它们分开在API中。
更好的结构是遵循数据库的结构:
sg
这将输出:
$iterator = 0;
$data = [];
while (($end = $sth->fetch()) && $iterator < 2)
{
$data[] = [
'tc'=> $end["tc"],
'em'=> $end["em"],
'sg'=> $end["sg"]
];
$iterator ++;
}
header('Content-Type: application/json');
echo json_encode([data=>$data]);
如果有结果,并且:
{
data:[
{tc: value_tc_1, em: value_em_1, sg: value_sg_1},
{tc: value_tc_2, em: value_em_2, sg: value_sg_2},
{tc: value_tc_3, em: value_em_3, sg: value_sg_3}
]
}
没有结果时。
消费者代码可以是例如(再次使用php,可以是任何语言):
{
data:[]
}
无论你的api是否返回结果,消费者代码都运行良好(如果没有结果,只显示一个空表)。
最后请注意,如果您的SQL更符合您的要求,例如:
$response = json_decode(file_get_contents($apiEndpoint));
foreach($response->data as $element){
echo '<tr><td>' . $element->tc . '</td><td>' . $element->em . '</td><td>' . $element->sg . '<td></tr>';
}
然后你的整个PHP代码变成:
SELECT tc, em, sg FROM tablename LIMIT 3
不需要迭代器,while循环等
答案 1 :(得分:1)
返回错误对象可保持一致性,并且很容易在客户端捕获:
假如没有找到数据,则返回此信息:
$api_arr["error"]["code"] = 404;
$api_arr["error"]["message"] = "No data found";
现在在客户端,在ajax请求中,有人可以轻松地执行此操作:
try {
if(typeof ajaxObj.error != 'undefined'){
throw ajaxObj.error;
}
//Data is found
} catch(errObj) {
//Handle the error object.
}