若是geoip获取地理位置能够知足你的需求可跳转:juejin.im/post/5d0c7e…laravel
地理编码/逆地理编码 API 是经过 HTTP/HTTPS 协议访问远程服务的接口,提供结构化地址与经纬度之间的相互转化的能力。web
结构化地址的定义: 首先,地址确定是一串字符,内含国家、省份、城市、区县、城镇、乡村、街道、门牌号码、屋邨、大厦等建筑物名称。按照由大区域名称到小区域名称组合在一块儿的字符。一个有效的地址应该是独一无二的。注意:针对大陆、港、澳地区的地理编码转换时能够将国家信息选择性的忽略,但省、市、城镇等级别的地址构成是不能忽略的。json
第一步,申请Web服务API类型Key;api
第二步,参考接口参数文档发起HTTP/HTTPS请求,第一步申请的 Key 需做为必填参数一同发送;bash
第三步,接收请求返回的数据(JSON或XML格式),参考返回参数文档解析数据。app
如无特殊声明,接口的输入参数和输出数据编码所有统一为 UTF-8 编码方式。框架
逆地理编码API服务地址curl
https://restapi.amap.com/v3/geocode/geo?parameters复制代码
address 是须要获取坐标的结构化地址,output(XML)用于指定返回数据的格式,Key是用户请求数据的身份标识。ide
city为指定查询的城市(为可选参数)post
逆地理编码API服务地址
https://restapi.amap.com/v3/geocode/regeo?parameters复制代码
location(116.310003,39.991957) 是所须要转换的坐标点经纬度,radius(1000)为返回的附近POI的范围,单位:米,extensions(all)为返回的数据内容,output(XML)用于指定返回数据的格式,Key 是高德Web服务 Key。
本次DEMO在laravel框架中实现(其余框架都可用相同方式实现)
/**
* 将详细的结构化地址转换为高德经纬度坐标-高德地图-地理编码
* @param string $address 填写结构化地址信息:省份+城市+区县+城镇+乡村+街道+门牌号码
* @param string $city 查询城市,可选:城市中文、中文全拼、citycode、adcode
* @return array
*/
public function geo($address = '', $city = '北京')
{
$key = config('app.amap_key');
/**
* url:https://restapi.amap.com/v3/geocode/geo?address=北京市朝阳区阜通东大街6号&output=XML&key=<用户的key>
* output(XML/JSON)用于指定返回数据的格式
*/
$url = "https://restapi.amap.com/v3/geocode/geo?output=JSON&key={$key}&address={$address}&city={$city}";
// 执行请求
$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_URL, $url);
$data = curl_exec($ch);
curl_close($ch);
$result = json_decode($data, true);
return $result;
}
/**
* 根据经纬度获取地理位置-高德地图-逆地理编码
* @param string $lon 经度
* @param string $lat 纬度
* @return array
*/
public function regeo($lon, $lat)
{
// Key 是高德Web服务 Key。详细能够参考上方的请求参数说明。
$key = config('app.amap_key');
// location(116.310003,39.991957) 是所须要转换的坐标点经纬度,经度在前,纬度在后,经纬度间以“,”分割
$location = $lon . "," . $lat;
/**
* url:https://restapi.amap.com/v3/geocode/regeo?output=xml&location=116.310003,39.991957&key=<用户的key>&radius=1000&extensions=all
* radius(1000)为返回的附近POI的范围,单位:米
* extensions 参数默认取值是 base,也就是返回基本地址信息
* extensions 参数取值为 all 时会返回基本地址信息、附近 POI 内容、道路信息以及道路交叉口信息。
* output(XML/JSON)用于指定返回数据的格式
*/
$url = "https://restapi.amap.com/v3/geocode/regeo?output=JSON&location={$location}&key={$key}&radius=1000&extensions=base";
// 执行请求
$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_URL, $url);
$data = curl_exec($ch);
curl_close($ch);
$result = json_decode($data, true);
return $result;
}复制代码
须要传递经纬度来获取当前的地理位置,详细见代码注释
如还有问题,具体api文档见:lbs.amap.com/api/webserv…