地理编码服务
地理编码服务(又名Geocoder)是一类Web API接口服务;
正地理编码服务提供将结构化地址数据(如:北京市海淀区上地十街十号)转换为对应坐标点(经纬度)功能;
地理编码服务当前未推出国际化服务,解析地址仅限国内;
功能介绍
地理编码服务
用户可通过该功能,将结构化地址(省/市/区/街道/门牌号)解析为对应的位置坐标。地址结构越完整,地址内容越准确,解析的坐标精度越高。
URL:http://lbsyun.baidu.com/index.php?title=webapi/guide/webservice-geocoding
以下是开发的代码,主要调取 getMap(); 方法:
'', // 待解析的地址,最多支持84个字节,(必须)
'output' => 'json', // 输出格式为json或者xml
'ak' => self::REQ_AK, // 用户申请注册的key,(必须)
'callback' => '', // 将json格式的返回值通过callback函数返回以实现jsonp功能,(我们不需要)
'city' => '', // 地址所在的城市名
'ret_coordtype' => 'gcj02ll', // 添加后返回国测局经纬度坐标或百度米制坐标,(gcj02ll:国测局坐标、bd09mc:百度墨卡托坐标)
'sn' => '', // 若用户所用ak的校验方式为sn校验时该参数必须
);
public function __construct()
{
}
/**
* 重置所有请求参数
* @param array $config 请求参数
* @param bool $isSn 是否使用sn校验
* @param string $sk
*/
public function setReqParam($config, $isSn = false, $sk = null)
{
if (is_array($config) && !empty($config)) {
foreach ($config as $key => $val) {
!empty($val) && $this->reqParam[$key] = $val;
}
}
if ($isSn) {
$this->isSn = true;
!empty($sk) && $this->sk = $sk;
}
}
/**
* 获取经纬度信息
* @param null|string $address 详细地址
* @param null|string $city 详细地址所属城市名,有利于精确返回信息
* @return bool|mixed 经纬度坐标:[... "location":{"lat":"纬度值","lng":"经度值"} ...]
*/
public function getMap($address = null, $city = null)
{
// 设置地址信息
!empty($address) && $this->reqParam['address'] = $address;
!empty($city) && $this->reqParam['city'] = $city;
if ($this->isSn) {
// 调用sn计算函数,默认get请求
$queryStringArrays = $this->reqParam;
unset($queryStringArrays['sn']);
$this->reqParam['sn'] = self::caculateAKSN($this->reqParam['ak'], $this->sk, self::REQ_URI, $queryStringArrays);
}
// 请求数据
$data = $this->send(self::REQ_URL, $this->reqParam);
// 处理请求数据
$data = str_replace('renderOption&&renderOption(', '', $data);
$data = str_replace(')', '', $data);
$data = json_decode($data, true);
// 返回数据
if (!empty($data)) {
if ($data['status'] == 0) {
return $data;
} else {
$this->errMsg = $data;
}
} else {
$this->errMsg = '请求出错了';
}
return false;
}
/**
* 返回错误信息
* @return array|string
*/
public function errMsg()
{
return $this->errMsg;
}
/**
* 发送请求
* @param $url
* @param $params
* @return mixed
*/
private function send($url, $params = null)
{
if (!empty($params)) {
if (is_array($params)) {
$paramStr = '';
foreach ($params as $k => $val) {
// 请求参数中有中文、特殊字符等需要进行urlencode,确保请求串与sn对应
if ($this->isSn && $k != 'sn') {
if (preg_match('/[\x{4e00}-\x{9fa5}]/u', $val) > 0) {
$val = urlencode($val);
}
}
$paramStr .= "{$k}={$val}&";
}
$paramStr = rtrim($paramStr,'&');
} else {
$paramStr = $params;
}
$url .= (strpos($url, "?") === false ? '?' : '&');
$url .= $paramStr;
}
// 记录一下url
$this->errMsg = $url;
$ch = curl_init();
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
// 执行并获取HTML文档内容
$result = curl_exec($ch);
// 释放curl句柄
curl_close($ch);
return $result;
}
/**
* sn计算函数,默认get请求
* 百度地图提供
* 文档URL:http://lbsyun.baidu.com/index.php?title=webapi/appendix
* @param $ak
* @param $sk
* @param $url
* @param $querystring_arrays
* @param string $method
* @return string
*/
private static function caculateAKSN($ak, $sk, $url, $querystring_arrays, $method = 'GET')
{
if ($method === 'POST') {
ksort($querystring_arrays);
}
$querystring = http_build_query($querystring_arrays);
return md5(urlencode($url . '?' . $querystring . $sk));
}
}
相关参数说明看文档:http://lbsyun.baidu.com/index.php?title=webapi/guide/webservice-geocoding