小版本更新了psr规范 之前对这方面了解不多,因此写的可能有点问题。 但是欢迎指出错误而不是带着一股子嘲讽过来喷人好吗。 用处不多维护精力比较少 但基本够用
php >=7.0.0
guzzlehttp/guzzlehttp:^6.3
没有安装guzzlehttp也不要紧,在require的时候回自动安装
composer require reprover/amap
use Reprover\Amap\Amap;
(1)
$amap = new Amap();
$gateway = $amap->uses("Georegeo")->gateway("geo")->build(["key"=>"你的api key",...其他选项]);
//这里支持setKey("key值");
//这里支持useHttps(true);
$result = $gateway->ask();
如果不需要额外的配置,可以用以下方法:
(2)
$gateway = Amap::use("georegeo")->gateway("regeo")->build(...);
$result = $gateway->ask();
(3) 如果请求的接口大类只有一个子方法(例如坐标转换),则可以省略gateway()方法
$gateway = Amap::use("convert")->build(...);
$result = $gateway->ask();
build方法传什么? 传$config参数,参数列表为一数组,具体实现为一Reprover/Support/Config对象,
返回结果为一个Reprover\AMap\Support\Result对象,类似于Laravel的Collection,不过没那么全面。可用的方法:
count() :int
所得数据结果数量,如果有多种类型结果则只返回主要数据(如天气只返回实时天气数量,天气预报也可以用$result->forecast)获取。
foreach($result as $k=>$v){...}
可以用foreach进行结果的循环
isValid() :boolean
判断结果是否正确,即根据高德返回数据status(errcode)是否为1(0)
部分特殊接口有一些特殊用法,开发ing
这个sdk是第一版,还存在很多不足的地方,欢迎大家提交pr和issue!同时也在版本迭代中,建议大家不要急于将此插件用于生产环境中~
- √ 优化类名和驼峰法命名
- √ 修改验证类规则(现在是一个方法,需要写一个类)
- √ 优化使用方法,注入配置项等
- 数字签名自动完成
- √ http与https的切换