如何解决如何使用 Google 距离矩阵获取两个位置之间的距离
<html>
<body>
<form action="" method="post">
<label>Origin:</label> <input type="text" name="o" placeholder="Enter Origin location" required> <br><br>
<label>Destination:</label> <input type="text" name="d" placeholder="Enter Destination location" required> <br><br>
<input type="submit" value="Calculate distance & time" name="submit"> <br><br>
</form>
<?PHP
$con = MysqLi_connect("localhost","root","","buspass");
if(isset($_POST['submit'])){
$origin = $_POST['o'];
$destination = $_POST['d'];
$api = file_get_contents("https://www.google.com/maps/search/?api=1&query=centurylink+field/distancematrix/json?units=imperial&origins=".$origin."&destinations=".$destination."&key=AIzaSyAWOoVKOdZ3xCEvoz735TBrggU0q7EgPsU");
$data = json_decode($api);
?>
<label><b>distance: </b></label> <span>
<?PHP
if (is_object($data)) {
echo((int)$data->rows[0]->elements[0]->distance->value / 1000).' Km'; //line24
}
?>
</span> <br><br>
<label><b>Travel Time: </b></label> <span>
<?PHP
if (is_object($data)) {
echo $data->rows[0]->elements[0]->duration->text; //line 31
}
?>
</span>
<?PHP
}
?>
</body>
</html>
当我输入两个位置并发布它时,应该输出两个位置之间的距离和大约需要到达的时间
错误信息
注意:试图获取非对象的属性“行” C:\xampp\htdocs\Bus Pass\distance.PHP 24行
注意:试图获取非对象的属性“元素” C:\xampp\htdocs\Bus Pass\distance.PHP 24行
注意:尝试获取非对象的属性“距离” C:\xampp\htdocs\Bus Pass\distance.PHP 24行
注意:试图获取非对象的属性“值” C:\xampp\htdocs\Bus Pass\distance.PHP on line 24 0 Km
旅行时间:注意:尝试获取非对象的属性“行” C:\xampp\htdocs\Bus Pass\distance.PHP 31行
注意:试图获取非对象的属性“元素” C:\xampp\htdocs\Bus Pass\distance.PHP 31行
注意:尝试获取非对象的属性“持续时间” C:\xampp\htdocs\Bus Pass\distance.PHP 31行
注意:试图获取非对象的属性“文本” C:\xampp\htdocs\Bus Pass\distance.PHP 31行
解决方法
我自己在使用 PHP 的 JSON 对象时遇到了一些困难,
1.将 $data = json_decode($api);
替换为 $data = json_decode($api,true);
以获得关联数组。
2.删除任何对象检查(如 if (is_object($data)) {
)。
3.最后,使用数组样式调用而不是对象样式,例如,更改您的代码:
$data->rows[0]->elements[0]->distance->value
变成类似:
$data['rows'][0]['elements'][0]['distance']['value']
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。