当前位置: 首页 > article >正文

Spring Boot 集成高德地图电子围栏

摘要:本文手把手教你通过 Spring Boot 调用高德地图 API 实现电子围栏功能,涵盖云端围栏创建设备位置监控本地算法校验,附带完整代码和避坑经验!


一、电子围栏核心原理

1.1 什么是电子围栏?

  • 虚拟地理边界:在地图上划定区域(圆形/多边形),触发进出事件
  • 应用场景:员工考勤、物流围栏、儿童安全区域监控
  • 技术核心:基于 GPS/北斗坐标的位置判断(射线法或API调用)

1.2 高德地图API能力

  • 云端围栏管理:创建、删除、查询围栏
  • 实时状态检测:设备进入/离开围栏时触发回调
  • 坐标系支持:GCJ-02(火星坐标系)

二、Spring Boot 集成高德API实战

2.1 环境准备

(1)添加 Maven 依赖
<!-- Web 基础依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 高德API HTTP 客户端 -->
<dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpclient</artifactId>
    <version>4.5.13</version>
</dependency>
(2)配置高德 Key

application.yml 中配置:

amap:
  key: your_amap_key  # 前往高德开放平台申请
  geo-fence-url: https://restapi.amap.com/v4/geofence/meta

2.2 核心代码实现

(1)高德API服务封装
@Service
public class AmapGeoFenceService {
    @Value("${amap.key}")
    private String amapKey;

    /**
     * 创建电子围栏(支持多边形)
     * @param name 围栏名称
     * @param points 坐标点(格式:lng1_lat1,lng2_lat2,...)
     * @return 围栏ID
     */
    public String createGeoFence(String name, String points) {
        RestTemplate restTemplate = new RestTemplate();
        String url = String.format("%s?key=%s&name=%s&points=%s", 
                geoFenceUrl, amapKey, URLEncoder.encode(name), points);
        
        ResponseEntity<String> response = restTemplate.postForEntity(url, null, String.class);
        // 解析返回结果获取 fence_id
        JsonNode root = JsonUtils.parse(response.getBody());
        return root.get("data").get("fence_id").asText();
    }
}
(2)业务逻辑层
@Service
@RequiredArgsConstructor
public class GeoFenceService {
    private final AmapGeoFenceService amapService;
    private final GeoFenceRepository fenceRepository;

    /**
     * 创建围栏并保存到数据库
     */
    @Transactional
    public String createFence(GeoFenceDTO dto) {
        // 坐标点格式转换
        String pointsStr = dto.getPoints().stream()
                .map(p -> p.getLng() + "_" + p.getLat())
                .collect(Collectors.joining(","));
        
        // 调用高德API
        String fenceId = amapService.createGeoFence(dto.getName(), pointsStr);
        
        // 保存到数据库
        GeoFence fence = new GeoFence();
        fence.setFenceId(fenceId);
        fence.setName(dto.getName());
        fenceRepository.save(fence);
        return fenceId;
    }
}

2.3 实现效果演示

(1)创建围栏 API 请求
POST /api/fences
Content-Type: application/json

{
  "name": "公司安全区",
  "points": [
    {"lng": 116.397504, "lat": 39.89619},
    {"lng": 116.407504, "lat": 39.89619},
    {"lng": 116.397504, "lat": 39.90619}
  ]
}
(2)返回结果
{
  "fenceId": "1234567890"
}

三、避坑指南

3.1 常见问题排查

问题现象原因分析解决方案
API返回INVALID_USER_KEY高德Key未配置或错误检查application.yml
围栏未触发通知设备未开启定位权限引导用户授权定位
坐标偏移严重坐标系不一致(如WGS-84)调用高德坐标转换API

3.2 性能优化建议

  • 本地缓存:使用 Redis 缓存围栏坐标数据,减少数据库查询
  • 批量校验:多个设备位置通过高德 batch/status 接口批量查询
  • 围栏简化:对多边形顶点做道格拉斯-普克抽稀算法处理

http://www.kler.cn/a/590239.html

相关文章:

  • DBA(数据库管理员)常用的 Linux 命令
  • 【开源免费】基于SpringBoot+Vue.JS电商应用系统(JAVA毕业设计)
  • HTML 基础夯实:标签、属性与基本结构的学习进度(一)
  • FPV无人机战术演练仿真系统技术详解
  • 网络世界探索之旅:初始网络
  • KUKA机器人编程之signal的应用(包括创建组输入和组输出)
  • Day09 -实例:拿到加密密文进行解密
  • Tomcat新手登峰指南:从零到部署的原子化实践
  • repo init 错误 Permission denied (publickey)
  • 机器学习扫盲系列(2)- 深入浅出“反向传播”-1
  • 3.17学习总结 java数组
  • 18.使用读写包操作Excel文件:xlrd、xlwt 和 xlutils 包
  • 浅谈AI落地之-关于数据增广的思考
  • Tomcat线程池详解,为什么SpringBoot最大支持200并发?
  • 从零搭建微服务项目Pro(第6-1章——Spring Security+JWT实现用户鉴权访问与token刷新)
  • 【前端】入门基础(一)html标签
  • Git 面试问题,解决冲突
  • ‌RTSPtoWeb, 一个将rtsp转换成webrtc的开源项目
  • C++之list类及模拟实现
  • Redis 安装详细教程(小白版)