利用百度地图api通过城市地址等信息取经纬度

Share on:

Geocoding API有哪些功能?

Geocoding API包括地址解析和逆地址解析功能。

  • 地址解析是指,由详细到街道的结构化地址得到百度经纬度信息,且支持名胜古迹、标志性建筑名称直接解析返回百度经纬度。例如:“北京市海淀区中关村南大街27号”地址解析的结果是“lng:116.31985,lat:39.959836”,“百度大厦”地址解析的结果是“lng:116.30815,lat:40.056885”

  • 逆地址解析是指,由百度经纬度信息得到结构化地址信息。例如:“lat:31.325152,lng:120.558957”逆地址解析的结果是“江苏省苏州市虎丘区塔园路318号”。注意: 1.因为Geocoding和反Geocoding使用的门址数据以及算法都不是一样的,所以会出现不能一一对应的现象。

    2.解析过程中可能会出现一对坐标值对应多个地址门牌信息,本接口将返回距离坐标点最近的一个地址门牌信息。

    使用限制

    目前无任何使用限制。请申请key,然后使用该接口。

    如何使用

    第一步,申请key,点击这里[获取密钥][1],申请key需要注册百度账号;

    第二步,拼写发送http请求的url,注意需使用第一步申请的key;

    第三步,接收http请求返回的数据(支持json和xml格式)。

    服务地址

    • 地址解析:根据地址获取坐标

    http://api.map.baidu.com/geocoder?address=地址&output=输出格式类型&key=用户密钥&city=城市名

    • 逆地址解析:根据坐标获取地址

    http://api.map.baidu.com/geocoder?location=纬度,经度&output=输出格式类型&key=用户密钥

    备注:

    1. city属于可选参数,通常情况可以不使用,若解析无结果,请尝试增加此字段。

    2. 支持名胜古迹、标志性建筑物名称解析返回百度经纬度坐标,如address=“百度大厦”。

    3. 支持使用“*路与*路交叉口”方式解析返回百度经纬度坐标,若地址库中存在该地址描述,返回百度经纬度坐标。

    4. 若解析status字段为OK,若结果内容为空,原因分析及可尝试方法:

    • 地址库里无此数据,本次结果为空。
    • 加入city字段重新解析;
    • 将过于详细或简单的地址更改至省市区县街道重新解析;
    1. 特别提醒:逆地址解析location参数传入的参数格式是(纬度lat,经度lng)。

    接口参数

    <th width="70px">
      是否必须
    </th>
        
    <th width="60px">
      默认值
    </th>
        
    <th width="220px">
      格式举例
    </th>
        
    <th width="255px">
      含义
    </th>
    
    <td>
      否
    </td>
        
    <td>
      json
    </td>
        
    <td>
      json或xml
    </td>
        
    <td>
      输出格式为json或者xml
    </td>
    
    <td>
      是
    </td>
        
    <td>
      无
    </td>
        
    <td>
      北京市海淀区上地十街10号
    </td>
        
    <td>
      根据指定地址进行坐标的反定向解析
    </td>
    
    <td>
      是
    </td>
        
    <td>
      无
    </td>
        
    <td>
      38.76623,116.43213<br /> lat<纬度>,lng<经度>
    </td>
        
    <td>
      根据指定坐标来进行地址的解析
    </td>
    
    <td>
      否
    </td>
        
    <td>
      “北京市”
    </td>
        
    <td>
      “广州市”
    </td>
        
    <td>
      地址所在的城市名
    </td>
    
    <td>
      是
    </td>
        
    <td>
      无
    </td>
        
    <td>
      8cb976834235d8cbcde2dce4835ae191
    </td>
        
    <td>
      用户申请注册的key
    </td>
    

    上表中address和location两个字段如果同时出现,则优先选择address执行地理编码功能。对于address字段可能会出现中文或其它一些特殊字符(如:空格),所以对于类似的字符都要进行编码处理,编码成 UTF-8 字符的二字符十六进制值,凡是不在下表中的字符都要进行编码。

    <th width="500px;">
      字符
    </th>
    
    <td>
      a b c d e f g h i j k l m n o p q r s t u v w x y z A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 0 1 2 3 4 5 6 7 8 9 &#8211; _ . ~
    </td>
    
    <td>
      ! * &#8216; ( ) ; : @ & = + $ , / ? % # [ ]
    </td>
    

    附注:

    (1) javascript中一般采用encodeURIComponent函数对特殊字符进行编码。

    (2) Java中可以使用函数URLEncoder.encode对特殊字符进行编码。

    (3) C#中可以使用函数HttpUtility.UrlEncode对特殊字符进行编码。

    (4) php中可以使用函数urlencode对特殊字符进行编码。

    返回数据说明

    返回结果(地址解析的结果)

{status: '字符串状态常量', 取值如下:
//OK 成功
INVILID_KEY 非法密钥 
INVALID_PARAMETERS 非法参数,参数错误时候给出。
result: {    
location: {
lat: 纬度:数值,
lng: 经度:数值
},
precise:’位置的附加信息,是否精确查找’(1为精确查找,0为不精确查找),
confidence: 可信度,
level:'级别'
},
}
返回结果(反地址解析的结果)

```
{status: '字符串状态常量', 取值如下:

//OK 成功 INVILID_KEY 非法密钥
INVALID_PARAMETERS 非法参数,参数错误时候给出。 result: {
location: { lat: 纬度:数值, lng: 经度:数值 }, formatted_address: ‘详细地址描述’, business: ‘周围商圈’, addressComponent:{ city:’城市名称’, district: ‘区县名称’, province:’省份名称’, street: ‘街道名称’, streetNumber: ‘门牌号码’ }, cityCode: ‘城市代码’ } }

   
   ## 接口示例 {#.E6.8E.A5.E5.8F.A3.E7.A4.BA.E4.BE.8B}
   
   根据详细地址获取坐标
   
   <a href="http://api.map.baidu.com/geocoder?address=%E4%B8%8A%E5%9C%B0%E5%8D%81%E8%A1%9710%E5%8F%B7&output=json&key=37492c0ee6f924cb5e934fa08c6b1676" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?address=%E4%B8%8A%E5%9C%B0%E5%8D%81%E8%A1%9710%E5%8F%B7&output=json&key=37492c0ee6f924cb5e934fa08c6b1676</a>
   
   //根据“上地十街10号”返回坐标“lng:116.307175, lat:40.057098”,以json格式输出
   
   <a href="http://api.map.baidu.com/geocoder?address=%E4%B8%8A%E5%9C%B0%E5%8D%81%E8%A1%9710%E5%8F%B7&output=xml&key=37492c0ee6f924cb5e934fa08c6b1676" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?address=%E4%B8%8A%E5%9C%B0%E5%8D%81%E8%A1%9710%E5%8F%B7&output=xml&key=37492c0ee6f924cb5e934fa08c6b1676</a>
   
   //根据“上地十街十号”返回坐标“lng:116.307175, lat:40.057098”,以xml格式输出  
   在指定城市内检索详细地址的坐标
   
   <a href="http://api.map.baidu.com/geocoder?address=%E4%B8%8A%E5%9C%B0%E5%8D%81%E8%A1%9710%E5%8F%B7&output=json&key=37492c0ee6f924cb5e934fa08c6b1676&city=%E5%8C%97%E4%BA%AC%E5%B8%82" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?address=%E4%B8%8A%E5%9C%B0%E5%8D%81%E8%A1%9710%E5%8F%B7&output=json&key=37492c0ee6f924cb5e934fa08c6b1676&city=%E5%8C%97%E4%BA%AC%E5%B8%82</a>
   
   // 在北京市内根据“上地十街10号”返回坐标“lng:116.307175, lat:40.057098”,以json格式输出
   
   <a href="http://api.map.baidu.com/geocoder?address=%E4%B8%8A%E5%9C%B0%E5%8D%81%E8%A1%9710%E5%8F%B7&output=xml&key=37492c0ee6f924cb5e934fa08c6b1676&city=%E5%8C%97%E4%BA%AC%E5%B8%82" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?address=%E4%B8%8A%E5%9C%B0%E5%8D%81%E8%A1%9710%E5%8F%B7&output=xml&key=37492c0ee6f924cb5e934fa08c6b1676&city=%E5%8C%97%E4%BA%AC%E5%B8%82</a>
   
   // 在北京市内根据“上地十街10号”返回坐标“lng:116.307175, lat:40.057098”,以json格式输出  
   根据特定建筑物获取它的坐标
   
   <a href="http://api.map.baidu.com/geocoder?address=%E7%99%BE%E5%BA%A6%E5%A4%A7%E5%8E%A6&output=json&key=37492c0ee6f924cb5e934fa08c6b1676" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?address=%E7%99%BE%E5%BA%A6%E5%A4%A7%E5%8E%A6&output=json&key=37492c0ee6f924cb5e934fa08c6b1676</a>  //根据“百度大厦”名称返回坐标“lng:116.307175, lat:40.057098”,以json格式输入
   
   <a href="http://api.map.baidu.com/geocoder?address=%E7%99%BE%E5%BA%A6%E5%A4%A7%E5%8E%A6&output=xml&key=37492c0ee6f924cb5e934fa08c6b1676" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?address=%E7%99%BE%E5%BA%A6%E5%A4%A7%E5%8E%A6&output=xml&key=37492c0ee6f924cb5e934fa08c6b1676</a>  //根据“百度大厦”名称返回坐标“lng:116.307175, lat:40.057098”,以xml格式输入  
   根据“\*路与\*路交叉路口”类型地址描述获得它的坐标
   
   <a href="http://api.map.baidu.com/geocoder?address=%E5%8C%97%E4%B8%80%E7%8E%AF%E8%B7%AF%E5%92%8C%E9%98%9C%E9%98%B3%E8%B7%AF%E7%9A%84%E4%BA%A4%E5%8F%89%E8%B7%AF%E5%8F%A3&output=json&key=37492c0ee6f924cb5e934fa08c6b1676" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?address=%E5%8C%97%E4%B8%80%E7%8E%AF%E8%B7%AF%E5%92%8C%E9%98%9C%E9%98%B3%E8%B7%AF%E7%9A%84%E4%BA%A4%E5%8F%89%E8%B7%AF%E5%8F%A3&output=json&key=37492c0ee6f924cb5e934fa08c6b1676</a>
   
   //根据“北一环路和阜阳路的交叉路口”名称返回坐标“lng:117.294364, lat:31.885558”,以json格式输入
   
   <a href="http://api.map.baidu.com/geocoder?address=%E5%8C%97%E4%B8%80%E7%8E%AF%E8%B7%AF%E5%92%8C%E9%98%9C%E9%98%B3%E8%B7%AF%E7%9A%84%E4%BA%A4%E5%8F%89%E8%B7%AF%E5%8F%A3&output=xml&key=37492c0ee6f924cb5e934fa08c6b1676" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?address=%E5%8C%97%E4%B8%80%E7%8E%AF%E8%B7%AF%E5%92%8C%E9%98%9C%E9%98%B3%E8%B7%AF%E7%9A%84%E4%BA%A4%E5%8F%89%E8%B7%AF%E5%8F%A3&output=xml&key=37492c0ee6f924cb5e934fa08c6b1676</a>
   
   //根据“北一环路和阜阳路的交叉路口”名称返回坐标“lng:117.294364, lat:31.885558”,以xml格式输入  
   根据坐标获取它的地址
   
   <a href="http://api.map.baidu.com/geocoder?output=json&location=39.983424,%20116.322987&key=37492c0ee6f924cb5e934fa08c6b1676" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?output=json&location=39.983424,%20116.322987&key=37492c0ee6f924cb5e934fa08c6b1676</a>
   
   //解析“lat:39.983424, lng:116.322987”坐标返回“北京市海淀区中关村大街27号1101-08室”,以json格式输出
   
   <a href="http://api.map.baidu.com/geocoder?output=xml&location=39.983424,%20116.322987&key=37492c0ee6f924cb5e934fa08c6b1676" rel="nofollow" target="_blank">http://api.map.baidu.com/geocoder?output=xml&location=39.983424,%20116.322987&key=37492c0ee6f924cb5e934fa08c6b1676</a>
   
   //解析“lat:39.983424, lng:116.322987”坐标返回“北京市海淀区中关村大街27号1101-08室”,以xml格式输出</li> </ul> 
   
   <span style="font-size: medium;"><strong>百度地址<a href="http://developer.baidu.com/map/geocoding-api.htm" target="_blank">http://developer.baidu.com/map/geocoding-api.htm</a></strong></span>

[1]: http://developer.baidu.com/map/apply-key.htm
闽ICP备12003472号-7