我试图通过搜索条件中到给定位置的距离来过滤搜索结果。每个报价都有自己的位置,包括(德国(邮政编码和所属城市。搜索条件包括相同的原则
因此,最终有搜索者的位置和报价的多个位置
此外,所有优惠都有一个半径,它们可以在其中操作
然后,我想筛选出所有与搜索者位置的距离大于其操作半径的报价
我使用过这个PHP代码:
$position = $_GET['position']!='' ? $_GET['position'] : '';
从我的URL中获取搜索者的位置。
$Results = $database->SearchResults('Conditions of the database Query');
它根据URL中的信息构建一个查询并搜索我的数据库。
while ($row = mysqli_fetch_array($Results)) {
echo $functions->GetDistance($position, $row[1], "K")."<br>";
}
这个while循环应该向我显示每个报价到搜索者位置的距离
function getDistance($addressFrom, $addressTo, $unit){
//Change address format
$formattedAddrFrom = str_replace(' ','+',$addressFrom);
$formattedAddrTo = str_replace(' ','+',$addressTo);
//Send request and receive json data
$geocodeFrom = file_get_contents('http://maps.google.com/maps/api/geocode/json?address='.$formattedAddrFrom.'&sensor=false');
$outputFrom = json_decode($geocodeFrom);
$geocodeTo = file_get_contents('http://maps.google.com/maps/api/geocode/json?address='.$formattedAddrTo.'&sensor=false');
$outputTo = json_decode($geocodeTo);
//Get latitude and longitude from geo data
$latitudeFrom = $outputFrom->results[0]->geometry->location->lat;
$longitudeFrom = $outputFrom->results[0]->geometry->location->lng;
$latitudeTo = $outputTo->results[0]->geometry->location->lat;
$longitudeTo = $outputTo->results[0]->geometry->location->lng;
//Calculate distance from latitude and longitude
$theta = $longitudeFrom - $longitudeTo;
$dist = sin(deg2rad($latitudeFrom)) * sin(deg2rad($latitudeTo)) + cos(deg2rad($latitudeFrom)) * cos(deg2rad($latitudeTo)) * cos(deg2rad($theta));
$dist = acos($dist);
$dist = rad2deg($dist);
$miles = $dist * 60 * 1.1515;
$unit = strtoupper($unit);
if ($unit == "K") {
return ($miles * 1.609344).' km';
}
else if ($unit == "N") {
return ($miles * 0.8684).' nm';
}
else {
return $miles.' mi';
}
}
这就是我在这个论坛上发现的获取两个地址之间距离的函数
它大部分时间都有效,我得到了正确的距离,例如:77.4640983104公里。
但每跑两三次,我就会得到这个错误:
注意:正在尝试获取非对象的属性
和
注意:未定义偏移:0
在"从地理数据获取纬度和经度"部分,并将0公里的错误距离作为输出
我真的不知道我犯了哪个错误,但我希望有人能向我解释,应该改变什么,或者整个事情是否以错误的方式处理
非常感谢您,祝您今天愉快!
注意:
如果将Google API-Key添加到URL中,则该功能确实有效。我发现的功能似乎是在使用地图商业化之前。