使用 React、Material-UI、Spring、MySQL、MyBatis 以及高德 API 模拟实时位置信息

news/2024/9/25 15:16:36/

要使用 React、Material-UI、Spring、MySQL、MyBatis 以及高德 API 模拟实时位置信息,你可以按以下步骤来实现:

目录

1. 前端 (React + Material-UI)

2. 后端 (Spring Boot + MyBatis + MySQL)

3. 模拟实时位置数据

4. 前后端联调


1. 前端 (React + Material-UI)

前端将负责展示实时位置信息,并使用 Material-UI 提供 UI 组件。

  • 安装依赖: 使用以下命令安装 React 和 Material-UI 相关依赖:

    npx create-react-app location-tracker
    cd location-tracker
    npm install @mui/material @emotion/react @emotion/styled axios
    
  • 创建高德地图显示位置

    • 你可以使用 react-amap 来与高德地图 API 进行集成。

      npm install react-amap
    • App.js 中使用高德地图组件:

      import React, { useState, useEffect } from 'react';
      import { Map, Markers } from 'react-amap';
      import axios from 'axios';const App = () => {const [positions, setPositions] = useState([]);useEffect(() => {const interval = setInterval(() => {// 从后端获取实时位置数据axios.get('/api/locations').then(response => {setPositions(response.data);}).catch(error => console.error('Error fetching locations:', error));}, 5000); // 每5秒获取一次return () => clearInterval(interval);}, []);return (<div style={{ width: '100%', height: '100vh' }}><Map amapkey="YOUR_AMAP_KEY"><Markersmarkers={positions.map(pos => ({position: { longitude: pos.lng, latitude: pos.lat }}))}/></Map></div>);
      };export default App;
      

2. 后端 (Spring Boot + MyBatis + MySQL)

后端将负责生成和提供模拟的位置信息。

  • 创建 Spring Boot 项目: 创建一个 Spring Boot 项目,包含 MyBatis 和 MySQL 依赖。

    <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.1.4</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency>
    </dependencies>
    
  • 配置数据库 (application.properties):

    spring.datasource.url=jdbc:mysql://localhost:3306/location_db?useSSL=false&serverTimezone=UTC
    spring.datasource.username=root
    spring.datasource.password=password
    mybatis.mapper-locations=classpath:mapper/*.xml
    
  • 创建数据库表

    创建一个 locations 表用于存储位置信息。

    CREATE TABLE locations (id BIGINT AUTO_INCREMENT PRIMARY KEY,lat DECIMAL(9,6) NOT NULL,lng DECIMAL(9,6) NOT NULL,timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP
    );
    
  • 创建 MyBatis Mapper: 定义 Mapper 接口和 XML 来从数据库查询位置信息。

    Mapper 接口 (LocationMapper.java):

    @Mapper
    public interface LocationMapper {@Select("SELECT * FROM locations ORDER BY timestamp DESC LIMIT 10")List<Location> getRecentLocations();
    }
    

    Mapper XML (LocationMapper.xml):

    <mapper namespace="com.example.mapper.LocationMapper"><select id="getRecentLocations" resultType="com.example.model.Location">SELECT * FROM locations ORDER BY timestamp DESC LIMIT 10</select>
    </mapper>
    
  • Location 实体类

    public class Location {private Long id;private BigDecimal lat;private BigDecimal lng;private Timestamp timestamp;// Getters and setters
    }
    
  • 编写控制器 (Controller): 创建一个 REST API 来提供实时位置信息。

    @RestController
    @RequestMapping("/api")
    public class LocationController {@Autowiredprivate LocationMapper locationMapper;@GetMapping("/locations")public List<Location> getRecentLocations() {return locationMapper.getRecentLocations();}
    }
    

3. 模拟实时位置数据

在实际应用中,位置信息可能来自 GPS 或者设备。你可以使用定时任务生成和插入随机的位置信息到数据库。

  • 随机生成位置

    你可以使用高德 API 提供的周边搜索来随机生成一些位置信息,或者手动生成一些经纬度数据。

    @Service
    public class LocationService {@Autowiredprivate LocationMapper locationMapper;private Random random = new Random();@Scheduled(fixedRate = 5000)public void generateRandomLocation() {BigDecimal lat = BigDecimal.valueOf(30 + random.nextDouble());BigDecimal lng = BigDecimal.valueOf(120 + random.nextDouble());locationMapper.insertLocation(new Location(lat, lng, new Timestamp(System.currentTimeMillis())));}
    }
    

    LocationMapper 中添加 insertLocation 方法:

    @Insert("INSERT INTO locations (lat, lng, timestamp) VALUES (#{lat}, #{lng}, #{timestamp})")
    void insertLocation(Location location);
    

4. 前后端联调

确保前端通过 Axios 向后端请求位置数据,并能够在高德地图上显示最新的位置。


通过这种方式,你可以使用 React 显示 Material-UI 风格的实时位置更新,并通过 Spring Boot、MyBatis 和高德 API 模拟并提供位置数据。


http://www.ppmy.cn/news/1530337.html

相关文章

PHP API 框架:构建高效API的利器【电商API接口】

在当今快速发展的互联网时代&#xff0c;API&#xff08;应用程序编程接口&#xff09;已成为连接不同应用程序和服务的关键。PHP&#xff0c;作为一种流行的服务器端脚本语言&#xff0c;提供了多种强大的框架来简化API的开发。本文将介绍PHP API框架的重要性&#xff0c;以及…

mysqli_fetch_object() 和 mysqli_fetch_array() 函数的区别

mysqli_fetch_object() mysqli_fetch_object() 函数用于从结果集中取得一行作为对象返回。这个对象反映了数据库表中的一行&#xff0c;其中对象的属性对应着表的列名。这个函数对于面向对象编程&#xff08;OOP&#xff09;的 PHP 开发者来说非常方便&#xff0c;因为它允许你…

TikTok直播推流不精准该怎么办?跟IP有关系吗?

TikTok&#xff0c;这款风靡全球的短视频社交平台&#xff0c;其直播功能已成为众多创作者与品牌宣传的利器。然而&#xff0c;不少用户却遭遇了直播推流不精准的难题&#xff0c;这直接影响到直播的曝光和互动效果。那么&#xff0c;面对这一问题&#xff0c;我们该如何应对&a…

vue配置axios

axios 是一个基于 Promise 的 HTTP 客户端&#xff0c;适用于浏览器和 node.js 环境。它提供了易于使用的 API 来发送异步 HTTP 请求到 REST 端点并处理响应。axios 因其简洁的 API 和广泛的浏览器兼容性而广受欢迎。 步骤一&#xff1a; 下载axios 在打开vue项目的编辑器中打…

Vue ElemetUI table实现双击修改编辑某个内容

1、使用cell-dblclick事件&#xff0c;当双击时触发事件 <el-table cell-dblclick"handleCellDblClick" 2、单元格设置 主要重点为判断双击时切换input框&#xff0c;然后绑定ref&#xff0c;设置失去焦点时触发点方法&#xff0c;与按enter键触发点方法 <…

(14)关于docker如何通过防火墙做策略限制

关于docker如何通过防火墙做策略限制 1、iptables相关问题 在Iptables防火墙中包含四种常见的表&#xff0c;分别是filter、nat、mangle、raw。 filter&#xff1a;负责过滤数据包。 filter表可以管理INPUT、OUTPUT、FORWARD链。 nat&#xff1a;用于网络地址转换。 nat表…

Uniapp低版本的安卓不能用解决办法

Uniapp低版本的安卓不能用解决办法 语法例子&#xff1a; 语法 不要使用过于新的语法规则 例子&#xff1a; 1. ${aa} 字符变量替换报错 换成连接&#xff0c; 2.let const 报错&#xff0c;换成 var 声明变量 3.includes() 报错 用indexOf替换 4.&#xff08;&#xff09;&…

银河麒麟高级服务器操作系统V10:提升普通用户操作权限

银河麒麟高级服务器操作系统V10&#xff1a;提升普通用户操作权限 1. 打开终端2. 切换到root用户&#xff08;可选&#xff09;3. 将用户加入到wheel组4. 验证用户组变更5. 使用sudo执行命令结论 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f4…