google 地图在 2018 年7月16之后,开始收费,所以当你需要用到google地图的服务的时候需要开通结算服务,获取到key,具体资费和服务内容 ,请参考google map官网google map用户指南
当我们有了地图的key之后,其实,获取响应的地图google提供了两种方法,一种是js,我们只需要在js里边请求,就可以将地图渲染到页面上,获取响应的参数;另一种则是server方法,通过http请求,然后google给我们响应,再将参数传到页面。
笔者的需求最初是用的google的地理编码API,因为需要地图显示,用的js的方式,当然需要显示地图的服务也贵一点。
google的地理编码API,js的方式
业务需求:用户输入一个地址,在下方获取到响应的地图位置,同时需要保存地址中的经纬度参数。
上边的address即客户在页面输入的地址。
上图就是当时没有结算的key,是带有 水印的,但是凑合看一下效果吧。
因为其实上边的地图并没什么实际作用,客户最初的需求也只是想要获取地址的经纬度,地图可有可无,后边发现,有专门的获取经纬度的服务,并且费用还低一些,于是乎,就有了后边的改需求。
google 地图 server方法 获取经纬度
这时候当用户输入地址的时候,我们只需要将用户输入的地址,传入到服务器,再请求google 的map就行了
JS代码
这里我就不写springmvc怎么通过requestMapping请求映射地址,获取页面数据,最后将map信息传入存入DB的操作了,我们直接看map怎么操作的。
写了一个工具类,去处理google 的http请求,google支持返回的result可以是json,xml类型。
状态代码
该"status"地址解析响应对象中字段包含请求的状态,并且可能会包含调试信息,以帮助您追查地理编码不工作。该"status"字段可能包含以下值:
- "OK"表示没有发生错误; 地址已成功解析,并且至少返回了一个地理编码。
- "ZERO_RESULTS"表示地理编码成功但未返回任何结果。如果地理编码器是不存在的,则可能会发生这种情况address。
- OVER_DAILY_LIMIT 表示以下任何一项: API密钥丢失或无效。 您的帐户尚未启用结算功能。 已超出自行使用上限。
提供的付款方式不再有效(例如,信用卡已过期)。 请参阅地图常见问题解答以了解如何解决此问题。 - “OVER_QUERY_LIMIT” 表示您已超过配额。 “REQUEST_DENIED” 表示您的请求被拒绝。
- "INVALID_REQUEST"通常表示缺少查询(address, components或latlng)。
- "UNKNOWN_ERROR"表示由于服务器错误而无法处理请求。如果再试一次,请求可能会成功。