跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
Javajava

Java 集成高德开放平台 Web API 实践:POI 搜索 2.0 示例

综述由AI生成如何在 Java 项目中集成高德开放平台的 WebAPI,重点演示了 POI 搜索 2.0 功能。内容涵盖 API 简介、请求参数说明、使用 Uniapi 库定义接口及业务调用代码示例。同时提供了常见问题处理建议及 API Key 安全保护方案,帮助开发者实现高效的地理信息服务集成。

NodeJser发布于 2026/4/6更新于 2026/5/2332 浏览
Java 集成高德开放平台 Web API 实践:POI 搜索 2.0 示例

前言

在数字化时代,地理信息系统(GIS)和位置服务(LBS)已成为许多应用程序的核心组成部分。高德开放平台作为国内领先的地理信息服务提供商,提供了丰富的 WebAPI 接口,帮助开发者快速集成地图、导航、搜索等功能。其中,POI(Point of Interest)搜索是许多应用场景中的关键功能。本文将以搜索 POI2.0 为例,详细介绍如何在 Java 项目中集成高德开放平台的 WebAPI,并实现高效的 POI 搜索功能。

一、高德搜索 API 简介

1、高德开放平台

高德开放平台提供了地图、定位、导航等 API 服务。为了获取更精准的数据参与分析,建议从高德平台获取数据。进入开放平台首页后可以看到产品介绍页面,点击搜索可进入具体的搜索专题介绍页面。

目前我们的搜索服务包括:POI 搜索、地理/逆地理编码、输入提示、天气及行政区域查询。

2、搜索功能介绍

平台的 POI 搜索 API 提供了多种搜索方式,包括关键字搜索、周边搜索、多边形搜索等。

  • 关键字搜索:开发者可通过文本关键字搜索地点信息,文本可以是结构化地址,例如:北京市朝阳区望京阜荣街 10 号;也可以是 POI 名称,例如:首开广场。
  • 周边搜索:开发者可设置圆心和半径,搜索圆形区域内的地点信息。
  • 多边形区域搜索:开发者可设置首尾连接的几何点组成多边形区域,搜索坐标对应多边形内的地点信息。
  • ID 搜索:开发者可通过已知的地点 ID(POI ID)搜索对应地点信息,建议结合输入提示接口使用。

POI 搜索 2.0 版本在原有功能的基础上,进一步优化了搜索算法,提升了搜索结果的准确性和响应速度。同时,API 还支持多种数据格式的返回,如 JSON、XML 等。

3、部分 API 介绍

关于开放平台接口的 API 介绍,官方有详细的说明,这里我们以按关键字搜索为例子,详细介绍它的请求参数以及响应参数信息。

关键字搜索 API 服务地址

URL请求方式
https://restapi.amap.com/v5/place/text?parametersGET

parameters 代表的参数包括必填参数和可选参数。所有参数均使用和号字符 (&) 进行分隔。

请求参数

参数名含义规则说明是否必须缺省值
key高德 Key用户在高德地图官网申请 Web 服务 API 类型 Key必填无
keywords地点关键字需要被检索的地点文本信息。只支持一个关键字,文本总长度不可超过 80 字符必填(keyword 或者 types 二选一必填)无
types指定地点类型地点文本搜索接口支持按照设定的 POI 类型限定地点搜索结果;地点类型与 poi typecode 是同类内容,可以传入多个 poi typecode,相互之间用''分隔可选(keyword 或者 types 二选一必填)
region搜索区划增加指定区域内数据召回权重,如需严格限制召回数据在区域内,请搭配使用 city_limit 参数可选无,默认全国范围内搜索
city_limit指定城市数据召回限制可选值:true/false;为 true 时,仅召回 region 对应区域内数据可选false
show_fields返回结果控制show_fields 用来筛选 response 结果中可选字段。具体可指定返回的字段类请见下方返回结果说明中的'show_fields'内字段类型可选空
page_size当前分页展示的数据条数page_size 的取值 1-25可选page_size 默认为 10
page_num请求第几分页请求第几分页可选page_num 默认为 1
sig数字签名请参考数字签名获取和使用方法可选无
output返回结果格式类型默认格式为 json,目前只支持 json 格式可选json
callback回调函数callback 值是用户定义的函数名称,此参数只在 output 参数设置为 JSON 时有效可选无

返回结果

名称类型说明
statusstring本次 API 访问状态,如果成功返回 1,如果失败返回 0。
infostring访问状态值的说明,如果成功返回"ok",失败返回错误原因
infocodestring返回状态说明,10000 代表正确,详情参阅 info 状态表
countstring单次请求返回的实际 poi 点的个数
poisobject返回的 poi 完整集合

poi 对象包含以下字段:

字段类型说明
namestringpoi 名称
idstringpoi 唯一标识
locationstringpoi 经纬度
typestringpoi 所属类型
typecodestringpoi 分类编码
pnamestringpoi 所属省份
citynamestringpoi 所属城市
adnamestringpoi 所属区县
addressstringpoi 详细地址
pcodestringpoi 所属省份编码
adcodestringpoi 所属区域编码
citycodestringpoi 所属城市编码

注意以下字段如需返回需要通过'show_fields'进行参数类设置:children, business, indoor, navi, photos 等详细子字段结构参考官方文档。

二、Uniapi 集成高德 API

本节详细介绍如何在 Java 中使用 Uniapi 来集成高德 api 实现相关的检索服务。主要从以下三个部分进行介绍:第一是介绍 API 的集成流程;第二是介绍如何在 Uniapi 中定义接口;第三是介绍如何在业务中进行集成。

1、API 集成流程

在 Java 项目中集成高德开放平台的 WebAPI,通常需要以下几个步骤:首先,开发者需要在高德开放平台注册账号,并创建应用以获取 API 密钥(Key)。其次,开发者需要在 Java 项目中引入 HTTP 客户端库,用于发送 HTTP 请求并接收 API 的响应。常用的 HTTP 客户端库包括 Apache HttpClient、OkHttp、Uniapi 等,本文将以 Uniapi 为例重点介绍。接下来,开发者需要根据高德 API 的文档,构建符合要求的请求 URL,并处理 API 返回的数据。

2、访问接口的定义

这里介绍如何在 Uniapi 中创建访问 api,用来跟开放平台进行交互,uniapi 的操作比较简单,下面是示例代码:

package com.yelang.project.thridinterface;

import com.burukeyou.uniapi.http.annotation.HttpApi;
import com.burukeyou.uniapi.http.annotation.param.QueryPar;
import com.burukeyou.uniapi.http.annotation.request.GetHttpInterface;
import com.burukeyou.uniapi.http.core.response.HttpResponse;

@HttpApi(url = "https://restapi.amap.com/v5")
public interface AmapSearchService {
    @GetHttpInterface("/place/text")
    public HttpResponse<String> getSearch(@QueryPar("keywords") String keywords,
                                          @QueryPar("types") String types,
                                          @QueryPar("region") String region,
                                          @QueryPar("page_size") String page_size,
                                          @QueryPar("page_num") String page_num,
                                          @QueryPar("show_fields") String show_fields,
                                          @QueryPar("key") String key);

    @GetHttpInterface("/place/polygon")
    public HttpResponse<String> searchByPolygon(@QueryPar("polygon") String polygon,
                                                @QueryPar("keywords") String keywords,
                                                @QueryPar("types") String types,
                                                @QueryPar("page_size") String page_size,
                                                @QueryPar("page_num") String page_num,
                                                @QueryPar("show_fields") String show_fields,
                                                @QueryPar("key") String key);
}

在上面的例子中,创建了两个访问接口。第一个方法是根据关键字来调用检索,第二个方法是根据一个 polygon 范围来进行检索。

3、业务调用集成

接下来讲解如何在 Java 当中调用 Uniapi 定义的接口,根据我们传入的参数来查询目标 POI。比如我们需要查询湖南省长沙市岳麓区(代码:430104)的餐饮服务(pot type:050000)的数据,每页数据返回的大小为 20 条数据。集成的访问代码如下:

package com.yelang.project.unihttp;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import com.burukeyou.uniapi.http.core.response.HttpResponse;
import com.google.gson.Gson;
import com.yelang.project.thridinterface.AmapSearchService;

@SpringBootTest
@RunWith(SpringRunner.class)
public class AmaPOISearchCase {
    private static final String AMAP_CLIENT_AK = "申请的访问 key";

    @Autowired
    private AmapSearchService amapSearchService;

    /**
     * - 关键字搜索 API 服务地址
     * @throws InterruptedException
     */
    @Test
    public void searchByKeyWordOrTypies() throws InterruptedException {
        String keywords = "餐饮";
        String types = "050000";
        String page_size = "20";
        String region = "430104";
        String show_fields = "children,business,indoor,navi,photos";
        
        HttpResponse<String> result = null;
        for (int i = 1; i <= 1; i++) {
            result = amapSearchService.getSearch(keywords, types, region, page_size, String.valueOf(i), show_fields, AMAP_CLIENT_AK);
            System.out.println(result.getBodyResult());
            Thread.sleep(3000L); // 休眠 3 秒
        }
    }
}

看到以下的信息说明返回成功,接口成功调用,下面我们将返回结果进行格式化。

三、常见问题与优化

在实际开发过程中,开发者可能会遇到一些常见问题,如 API 调用频率限制、数据解析错误、网络请求超时等。针对这些问题,开发者可以通过合理的代码设计和异常处理机制,确保系统的稳定性和可靠性。

在实际项目开发过程中,需要注意相关 key 的保护问题。这里使用的明文保存的方式,在使用高德 API 时需要注意的安全性问题,如 API Key 的保护、数据传输的加密等。可以采用加密的方式对明文进行保存,在访问时进行解密即可。

四、总结

本文详细介绍了如何在 Java 项目中集成高德开放平台的 WebAPI,并实现高效的 POI 搜索功能。示例涵盖了从 API 密钥的获取、HTTP 请求的发送、数据的解析到最终结果的展示等完整流程。通过本文的学习,开发者将能够掌握 Java 与高德开放平台 WebAPI 集成的基本方法,并能够根据实际需求,灵活应用这些技术解决实际问题。

目录

  1. 前言
  2. 一、高德搜索 API 简介
  3. 1、高德开放平台
  4. 2、搜索功能介绍
  5. 3、部分 API 介绍
  6. 二、Uniapi 集成高德 API
  7. 1、API 集成流程
  8. 2、访问接口的定义
  9. 3、业务调用集成
  10. 三、常见问题与优化
  11. 四、总结
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • WebPShop 插件:Photoshop 实现 WebP 格式全功能支持
  • MiGPT GUI 部署小爱音箱接入 AI 及内网穿透配置
  • Intel GPU 加速 llama.cpp:SYCL 后端配置与性能调优指南
  • VSCode 中关闭 GitHub Copilot 自动补全的方法
  • Go语言中的未来:从泛型到WebAssembly
  • CentOS 更换阿里云 YUM 源教程
  • 基于 OpenClaw 与 Open WebUI 搭建企业多部门私有化 AI 平台
  • OpenClaw 对接 QQ 机器人:本地与腾讯云部署实战
  • 3ds Max VR 渲染器及原生局部渲染设置
  • IntelliJ IDEA 入门指南:从零创建并运行 Java 项目
  • Java Web 开发:JSON 基础、@Test 测试与 Cookie Session 请求处理
  • Redis List 数据类型详解与 Java 实战
  • PicoClaw 轻量级 AI 助手安装与使用指南
  • DeepSeek R1 7B 在 RK3588 上的 RKLLM 转换与 Web 部署流程
  • AI 产品经理核心人工智能技术概览
  • PDFPatcher 开源 PDF 处理工具五大技术突破解析
  • 突破亚马逊壁垒,Web Unlocker API 助您轻松获取数据
  • VSCode Copilot 接入 OpenAI 兼容自定义模型方案
  • 国产 DSP FT-M6678 的 EMIF 接口开发避坑指南
  • 基于 OpenClaw 和飞书搭建 7x24 小时服务器运维机器人

相关免费在线工具

  • Keycode 信息

    查找任何按下的键的javascript键代码、代码、位置和修饰符。 在线工具,Keycode 信息在线工具,online

  • Escape 与 Native 编解码

    JavaScript 字符串转义/反转义;Java 风格 \uXXXX(Native2Ascii)编码与解码。 在线工具,Escape 与 Native 编解码在线工具,online

  • JavaScript / HTML 格式化

    使用 Prettier 在浏览器内格式化 JavaScript 或 HTML 片段。 在线工具,JavaScript / HTML 格式化在线工具,online

  • JavaScript 压缩与混淆

    Terser 压缩、变量名混淆,或 javascript-obfuscator 高强度混淆(体积会增大)。 在线工具,JavaScript 压缩与混淆在线工具,online

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online