news 2026/5/16 1:18:24

高德地图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/5/14 16:16:24

【Docker私有仓库搭建全攻略】:手把手教你安全推送镜像的5大核心步骤

第一章&#xff1a;Docker私有仓库推送概述在企业级容器化部署中&#xff0c;使用私有仓库管理镜像成为保障安全与提升效率的关键环节。Docker私有仓库允许团队在内部网络中存储、分发和控制镜像访问权限&#xff0c;避免敏感代码暴露于公共 registry。私有仓库的核心优势 增强…

作者头像 李华
网站建设 2026/5/12 7:33:39

我的秋招经历,大厂AI岗位面试真题总结

本文是在备战2025秋招过程中整理的面试“八股”合集。 本人主要投递的岗位包括&#xff1a;大模型算法工程师、Agent工程师、AI开发工程师、算法评测工程师等&#xff0c;面试公司以国内互联网中大厂为主。因此&#xff0c;本文中的问题深度和广度都围绕这些岗位的要求展开&…

作者头像 李华
网站建设 2026/5/15 10:54:02

重塑人机共生:Deepoc具身模型让居家机器人成为“懂生活的伙伴”

当智能家居成为生活标配&#xff0c;居家机器人本应是解放双手、提升生活品质的核心力量。但现实却是&#xff0c;多数产品停留在“机械执行指令”的初级阶段——听不懂模糊需求、看不懂复杂环境、做不好精细操作&#xff0c;让“智能”沦为噱头。Deepoc具身模型外拓板以“懂需…

作者头像 李华
网站建设 2026/5/15 19:23:44

优惠券发放规则:老用户复购享受折扣

VibeThinker-1.5B-APP&#xff1a;小模型如何实现推理“超车” 在大模型军备竞赛愈演愈烈的今天&#xff0c;一个仅15亿参数的小模型却悄然在数学与编程领域掀起波澜——VibeThinker-1.5B-APP。它没有千亿级的庞大规模&#xff0c;也不主打多模态或通用对话能力&#xff0c;而…

作者头像 李华
网站建设 2026/5/10 4:12:00

【Java毕设全套源码+文档】基于JavaWeb的房产信息管理系统的设计与实现(丰富项目+远程调试+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华