在web开发涉及地图操作的时候或者移动客户端开发中有时候有以下需求:
下面主要记录通过百度提供的API的一个解决方案:
在百度开发平台中提供了这样一个叫Geocoding 的API,这个API用于提供从地址到经纬度坐标或者从经纬度坐标到地址的转换服务,使用的是http协议,返回JSON或者XML数据。
地理编码:即地址解析,由详细到街道的结构化地址得到百度经纬度信息,例如:“北京市海淀区中关村南大街27号”地址解析的结果是“lng:116.31985,lat:39.959836”。同时,地理编码也支持名胜古迹、标志性建筑名称直接解析返回百度经纬度,例如:“百度大厦”地址解析的结果是“lng:116.30815,lat:40.056885” ,通用的POI检索需求,建议使用Place API。
逆地理编码:即逆地址解析,由百度经纬度信息得到结构化地址信息,例如:“lat:31.325152,lng:120.558957”逆地址解析的结果是“江苏省苏州市虎丘区塔园路318号”。
使用限制:
百度地图Geocoding API是一套免费对外开放的API,默认配额100万次/天。
使用方法:
第一步:申请ak(即获取密钥),若无百度账号则首先需要注册百度账号。
第二步,拼写发送http请求的url,注意需使用第一步申请的ak。
第三步,接收http请求返回的数据(支持json和xml格式)。
Hello, World示例:
发送一个地址是“百度大厦”的请求,返回该地址对应的地理坐标。示例URL如下:
案例:
1、封装工具类
class Tools { public static $lngLatUrl = ‘http://api.map.baidu.com/geocoder/v2/‘;//请求地址 public static $ak = ‘4UgeXHtyx6ahqmnsFPP7SnHpE‘;//用户申请注册的key /** * 百度地图API,通过省份/城市/区县 获取对应地址的经纬度 * @param string $city 省份/城市/区县 * @param string $address 省份/城市/区县或更详细的地址 * @param string $output 返回数据的格式 */ public static function lngLat($address,$city = ‘‘,$output = ‘json‘) { $res = json_decode(file_get_contents(self::$lngLatUrl."?ak=".self::$ak."&output=".$output."&address=".urlencode($address)."&city=".urlencode($city))); if ($res->status == 0) { return $res->result->location; } return false; } }
2、调用API
public function Api() { $address = ‘南京市‘; $city = ‘江苏省‘; $res = Tools::lngLat($address,$city); var_dump($res); }
3、打印的结果
object(stdClass)[104] public ‘lng‘ => float 118.77807440803 public ‘lat‘ => float 32.057235501806
更详细的介绍:http://developer.baidu.com/map/index.php?title=webapi/guide/webservice-geocoding