news 2026/4/16 14:02:22

高德地图API的核心使用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
高德地图API的核心使用

高德 Web 服务 API 向开发者提供HTTP 接口,开发者可通过这些接口使用各类型的地理数据服务,返回结果支持JSON 和 XML格式。

--需要用到哪个API就去文档上找url,主要就是给这个url发起请求然后解析数据获取数据高德地图APIhttps://amap.apifox.cn/doc-537179如果还没注册,就先看文档跟着步骤,非常详细有手就行

--在基础API文档里就是我们一般用的多的API

-- 按着他的这个调试,先自己改改参数,玩一玩(介绍的非常详细)

然后我们整合API自己使用的时候

就是向这个url发送请求获取响应的过程

也就是这个所以我们就按这个url拼接发送请求就行了

可以发现每个API前面https://restapi.amap.com/v3/geocode/geo?·都是固定的,我们需要按格式处理后面的拼接参数

一个裸奔版供测试

裸奔版

<dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.8.25</version> </dependency>

地址转经纬度+获取响应


import cn.hutool.http.HttpRequest; import cn.hutool.json.JSONObject; import cn.hutool.json.JSONUtil; import java.util.HashMap; import java.util.Map; ​ public class AmapResponseDemo { public static void main(String[] args) { // 1. 准备请求要素(核心:URL + 参数) String apiUrl = "https://restapi.amap.com/v3/geocode/geo"; // 地理编码 API URL String amapKey = "你的高德API密钥"; // 替换为自己的 key ​ // 请求参数(必传:key + address,可选:city) Map<String, Object> paramMap = new HashMap<>(); paramMap.put("key", amapKey); // 高德密钥(必传) paramMap.put("address", "北京市朝阳区天安门"); // 待转换地址(必传) paramMap.put("city", "北京"); // 限定城市(可选,提高精度) paramMap.put("output", "json"); // 返回格式(必传,JSON) ​ // 2. 发送 GET 请求 + 获取响应体(核心步骤) String responseBody = HttpRequest.get(apiUrl) // 指定 URL 和请求方式(GET) .form(paramMap) // 传入参数(Hutool 自动拼接为 key=value&...,自动编码中文) .timeout(5000) // 连接超时(5秒) .readTimeout(5000) // 读取超时(5秒) .execute() // 执行请求(真正发起网络调用) .body(); // 获取响应体(API 返回的 JSON 字符串) ​ // 3. 解析响应数据(从 JSON 中提取需要的信息) JSONObject responseJson = JSONUtil.parseObj(responseBody); // 字符串转 JSON 对象 ​ // 3.1 先校验响应是否成功(高德 API 规则:status=1 表示成功) if ("1".equals(responseJson.getStr("status"))) { // 3.2 提取核心数据(如经纬度) String location = responseJson.getJSONArray("geocodes") // 结果数组 .getJSONObject(0) // 取第一个匹配结果(最精准) .getStr("location"); // 经纬度字符串(格式:"经度,纬度") ​ // 3.3 打印结果 System.out.println("API 响应体(JSON 字符串):" + responseBody); System.out.println("解析后的经纬度:" + location); } else { // 3.4 响应失败:打印错误信息(高德 API 的 info 字段是错误描述) String errorMsg = responseJson.getStr("info"); String errorCode = responseJson.getStr("infocode"); System.out.println("请求失败:错误信息=" + errorMsg + ",错误码=" + errorCode); } } }
  • 核心代码就这个

String responseBody = HttpRequest.get(apiUrl) .form(paramMap) .timeout(5000) .readTimeout(5000) .execute() .body();

向url发送GET请求(高德地图一般都是GET)

.form(拼接参数)

.execute():触发请求发送(建立和高德服务器的连接,发送数据)

然后.body()获取响应体(返回的是JSON格式)

最后用JSONUtil.parseOBJ(responseBody)解析JSON,按高德API字段名提取数据

提取k-v的值,需要去文档里查看这个字段名:

比如:像这样

bi

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 2:33:39

质量门禁2.0:GitLab MR中AI风险预测阻断高危代码的技术方案

一、方案背景与问题定位 传统门禁的局限性 规则库维护成本高&#xff08;平均每周消耗15人时&#xff09; 漏报率&#xff1e;34%&#xff08;2025年行业报告数据&#xff09; 仅能拦截语法/基础规范问题 AI赋能的必要性 graph LR A[MR提交] --> B[AI风险预测引擎] B --…

作者头像 李华
网站建设 2026/4/16 12:26:43

2.31 机器学习神器项目实战:如何在真实项目中应用XGBoost等算法

2.31 机器学习神器项目实战:如何在真实项目中应用XGBoost等算法 引言 本文通过真实项目案例,演示如何在项目中应用XGBoost等机器学习神器。从数据准备、特征工程、模型训练到部署上线,提供完整的实战流程。 一、项目背景 1.1 项目需求 # 项目背景 def project_backgrou…

作者头像 李华
网站建设 2026/4/12 17:45:51

2.32 男女声音识别实战:音频特征提取与分类模型构建完整案例

2.32 男女声音识别实战:音频特征提取与分类模型构建完整案例 引言 本文通过男女声音识别案例,演示如何从音频数据中提取特征,构建分类模型。这是音频分析的基础应用,涉及特征工程、模型训练等完整流程。 一、音频特征提取 1.1 常用特征 # 音频特征提取 def audio_feat…

作者头像 李华
网站建设 2026/4/16 11:53:23

在线判题系统OJ接入VibeThinker提供智能提示功能

在线判题系统OJ接入VibeThinker提供智能提示功能 在编程学习的道路上&#xff0c;大多数人都曾经历过这样的时刻&#xff1a;面对一道算法题绞尽脑汁&#xff0c;提交十几次却始终是“Wrong Answer”&#xff0c;而系统只冷冰冰地返回一个“WA”——没有解释、没有引导&#xf…

作者头像 李华
网站建设 2026/4/15 7:42:30

揭秘Docker镜像推送失败原因:80%开发者忽略的3个关键配置

第一章&#xff1a;揭秘Docker镜像推送失败的根源在使用Docker进行容器化开发与部署时&#xff0c;镜像推送是关键一环。然而&#xff0c;开发者常遇到镜像无法成功推送到远程仓库的问题。这类问题通常源于认证、网络配置或镜像标签不规范等常见原因。认证信息缺失或错误 推送镜…

作者头像 李华
网站建设 2026/4/16 13:34:36

抖音短视频创意:用VibeThinker解高考数学题吸粉

抖音短视频创意&#xff1a;用VibeThinker解高考数学题吸粉 在抖音上刷到一道压轴导数题的详细推导&#xff0c;步骤清晰、公式规范&#xff0c;甚至比老师的板书还工整——你以为是哪个清北学霸熬夜录的讲解&#xff1f;其实背后可能根本没有人类出镜。真正的“主讲人”是一个…

作者头像 李华