此代码应从 JSON 文件中提取,并在表中显示值,并针对 API 返回的每个 IP 实例进行循环。我没有在表格中显示条目,而是得到一个空白表格。有任何想法吗?
这是使用 Vultr API,如果您想知道那是什么,我用 X 掩盖了我的 SUBID 和 API 密钥。我知道这种方法有效,因为我以前用相同的 API 使用过它。我的理论是我的问题源于使用 [] 返回的 JSON。
我有以下 JSON 进来:
{"30953157":[{"ip":"207.148.0.160","netmask":"255.255.254.0","gateway":"207.148.0.1","type":"main_ip","reverse":"brazos.cwservernetwork.com"},{"ip":"144.202.69.201","netmask":"255.255.254.0","gateway":"144.202.68.1","type":"secondary_ip","reverse":"brazos.cwservernetwork.com"}]}
PHP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>List IP</title>
<meta http-equiv="Content-Style-Type" content="text/css" />
</head>
<body>
<table width="1800px">
<tr>
<td colspan="6"><h1><b><u>Listing IPv4</h1></u></b></td>
</tr>
<tr>
<td style="text-align:center"><b>IPv4</b></td>
<td style="text-align:center"><b>Netmask</b></td>
<td style="text-align:center"><b>Gateway</b></td>
<td style="text-align:center"><b>Type</b></td>
<td style="text-align:center"><b>Reverse</b></td>
</tr>
<?php
$myVultrApiKey="XXXXXXXXXXXXXXXXXXXXXX";
$loadingtime = time();
$json = file_get_contents("https://api.vultr.com/v1/server/list_ipv4?api_key=$myVultrApiKey&SUBID=XXXXXXXXX");
$data = json_decode($json);
print $json;
foreach ($data as $name => $value)
{
?>
<tr>
<td style="text-align:center"><?php echo $value->ip; ?></td>
<td style="text-align:center"><?php echo $value->netmask; ?></td>
<td style="text-align:center"><?php echo $value->gateway; ?></td>
<td style="text-align:center"><?php echo $value->type; ?></td>
<td style="text-align:center"><?php echo $value->reverse; ?></td>
<?php
}//end for
?>
</tr>
<tr>
<td colspan="2">
<br><br><br><br><br>
<?php echo "Load Time: " . "<font color=\"green\">" . (time() - $loadingtime) . "s </font><br />\n"; ?>
</td>
</tr>
</table>
</body>
</html>