首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PHP json_decode显示到表格中

PHP json_decode显示到表格中
EN

Stack Overflow用户
提问于 2019-12-05 03:03:57
回答 2查看 293关注 0票数 0

此代码应从JSON文件中提取,并在表中显示这些值,并针对API返回的每个IP实例进行循环。我只是得到一个空表,而不是显示表中的条目。有什么想法吗?

这是使用Vultr API,如果您想知道这是什么,我用X屏蔽了我的SUBID和API密钥。我知道这个方法是有效的,因为我以前在相同的API中使用过它。我的理论是,我的问题源于JSON与[]一起返回。

我准备了以下JSON:

代码语言:javascript
复制
{"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:

代码语言:javascript
复制
<!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>
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-12-05 03:18:03

问题是你想要的数据在数据中是低一级的。显示数据应该会给您提供类似于...

代码语言:javascript
复制
stdClass Object
(
    [30953157] => Array
        (
            [0] => stdClass Object

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

代码语言:javascript
复制
foreach (array_values((array)$data)[0] as $name => $value)

应该做这件事。

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

代码语言:javascript
复制
foreach (reset($data) as $name => $value)
票数 0
EN

Stack Overflow用户

发布于 2019-12-05 03:16:43

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

试一试

代码语言:javascript
复制
foreach ($data->{30953157} as $name => $value) { ... }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59183047

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档