0

此代码应从 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>

    &nbsp;&nbsp;&nbsp;&nbsp;

    <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>
4

2 回答 2

0

导致问题的原因是 JSON 字符串开头的“30953157”。

尝试

foreach ($data->{30953157} as $name => $value) { ... }
于 2019-12-04T19:16:43.420 回答
0

问题是您所追求的数据在数据中下降了 1 级。显示数据应该会给你类似......

stdClass Object
(
    [30953157] => Array
        (
            [0] => stdClass Object

由于我不确定是否30953157已修复,因此修复方法是将其转换为数组并用于array_values()删除此键,然后仅访问元素[0]...

foreach (array_values((array)$data)[0] as $name => $value)

应该这样做。

或来自https://stackoverflow.com/a/18526290/1213708

foreach (reset($data) as $name => $value)
于 2019-12-04T19:18:03.427 回答