从各种ip数据库互联网服务中获取最佳经纬度响应


Getting best latitude longitude response form various ip database internet services

我有一个网站,可以在许多在线数据库中检查用户的ip地址,并获得纬度和经度的响应。

这里有一个例子:

Array
(
    [0] => stdClass Object
        (
            [statusCode] => OK
            [statusMessage] => 
            [ipAddress] => 37.6.226.186
            [countryCode] => GR
            [countryName] => GREECE
            [regionName] => ATTIKI
            [cityName] => ATHENS
            [zipCode] => -
            [latitude] => 37.9795
            [longitude] => 23.7162
            [timeZone] => +03:00
        )
    [1] => stdClass Object
        (
            [ip] => 37.6.226.186
            [country_code] => GR
            [country_name] => Greece
            [region_code] => 
            [region_name] => 
            [city] => 
            [zipcode] => 
            [latitude] => 39
            [longitude] => 22
            [metro_code] => 
            [areacode] => 
        )
    [2] => stdClass Object
        (
            [source] => smart-ip.net
            [host] => 37.6.226.186
            [lang] => en
            [countryName] => Greece
            [countryCode] => GR
            [city] => 
            [region] => 
            [latitude] => 39.0000
            [longitude] => 22.0000
            [timezone] => 
        )
)

我注意到,有时1个响应可能会完全显示不相关的地方,因此纬度+经度不好。

你将如何解决这样的问题?也许循环查看结果并检查最接近的值,然后选择1个响应?由于我是php专业的大三学生,所以我对此并不确定。任何指导或参考都将不胜感激。

您无法确定哪些坐标是最好的。任何值都可能是正确的,即使是看似无关紧要的值。更有可能的是,没有一个值是正确的。

如果要选择一个值,请随机选择一个。它和其他的一样好。

另一种选择是将一些算法应用于所有值(例如,记录最多的城市的平均值或记录最多的10英里半径内的平均值)。