文章目录
详细视频演示
文章底部名片,获取项目的完整演示视频,免费解答技术疑问
项目介绍
Spring Boot 基于微信小程序的个人健康运动辅助系统,旨在充分融合移动互联网与健康运动理念,借助 Spring Boot 强大的后端架构支撑能力,依托微信小程序便捷的移动端入口,为用户打造一个个性化、智能化的私人运动健康伴侣。它能够打破传统运动管理的局限,让用户随时随地记录运动数据、获取专业运动建议、追踪健康指标,激发运动积极性,助力养成良好运动习惯,提升全民健康水平。
技术介绍
开发语言:Java
框架:springboot
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql
数据库工具:Navicat11
开发软件:eclipse/myeclipse/idea
Maven包:Maven
安卓框架:uniapp
安卓开发软件:HBuilder X
开发模式:混合开发
功能介绍
(一)后端开发(Spring Boot 框架)
1.高效项目架构搭建:
1.采用经典的 Spring Boot 分层架构,由控制器层(Controller)、服务层(Service)、数据访问层(Repository)和实体层(Entity)构成。控制器层负责接收小程序前端发来的用户请求,如用户的运动数据上传请求、教练的学员信息查询请求等,并将其转发给服务层相应方法处理。服务层承载核心业务逻辑,如用户管理逻辑、运动管理逻辑、教练管理逻辑等,它调用数据访问层与数据库交互,获取或更新数据。数据访问层借助 Spring Data JPA 等技术与数据库对接,定义实体类(如用户实体、运动实体、教练实体、饮食实体等)映射数据库表结构,通过 Repository 接口实现数据的增删改查操作。实体层明确系统的数据对象模型,与数据库表结构一一对应,确保数据一致性与完整性。
1.可靠数据库选型与设计:
1.通常选用关系型数据库,如 MySQL 或 PostgreSQL,存储系统关键数据。依据小程序功能模块精心设计数据库表结构,主要包括用户表(存储用户基本信息、运动目标、历史运动数据等)、运动表(存储运动类型、运动数据、运动时间等)、教练表(存储教练基本信息、学员关系等)、饮食表(存储食谱信息、食材信息等)等。在数据库设计中,合理设置表间关联关系与主键、外键约束,确保数据完整与一致。例如,运动表中的用户 ID 作为外键关联用户表,便于查询某用户的运动历史;教练表中的学员 ID 作为外键关联用户表,方便教练管理学员。同时,结合数据查询热度与业务需求,科学设计索引,如在用户表中对手机号、身份证号等字段建立索引,提高数据查询效率。
1.安全接口设计与防护:
1.遵循 RESTful 风格设计接口,实现与小程序前端流畅通信,依托 HTTP 协议传输数据。小程序前端通过 GET 请求获取运动计划,通过 POST 请求提交运动数据。接口设计兼顾简洁规范与可扩展性,每个接口对应特定资源操作,采用标准 HTTP 方法(如 GET、POST、PUT、DELETE)标明操作类型。在接口安全方面,采用身份验证和授权机制。用户登录时,通过手机号验证码验证身份,验证通过生成 JWT(JSON Web Token)令牌并返回给用户。用户在后续请求中携带该令牌,后端验证令牌的合法性确保请求来自合法用户。同时,依据用户角色(用户、教练、管理员)限制接口资源访问权限,防止数据泄露与恶意攻击。例如,用户不能调用教练权限的接口修改学员运动计划。
(二)前端开发(小程序端)
1.友好界面设计:
1.运用微信小程序开发框架,结合 WXML、WXSS 和 JavaScript 技术,打造简洁、美观、易用的前端界面。以用户体验为核心,首页突出运动记录、计划查看、社区入口等常用功能,采用大图标、醒目颜色引导用户操作;运动记录页面以动态图表实时展示运动轨迹、数据变化,增强直观感受;社区页面设计类似社交平台,流畅展示帖子、图片、视频,方便用户互动。同时,针对不同手机屏幕尺寸进行自适应设计,确保页面在各种移动设备上完美适配、交互流畅。高度重视页面加载速度优化,运用图片压缩、代码合并与压缩、异步加载等技术手段,削减页面加载时间,提升用户体验。
1.流畅交互功能实现:
1.巧用小程序 API 与 JavaScript 脚本,实现丰富交互功能。在用户运动数据记录时,前端实时校验数据合法性,如运动时长不能为负数、卡路里消耗需在合理区间等,用户提交数据后,通过小程序内置的网络请求方法与后端无缝交互,实现无刷新页面更新,将运动数据安全送达服务器;在运动计划定制环节,前端根据用户输入信息即时反馈初步计划,通过网络请求与后端交互,获取最终精准计划;在社区互动场景,前端实时更新点赞、评论数量,通过网络请求与后端交互,存储互动信息。且与后端 Spring Boot 应用始终遵循 HTTP 协议交互,采用 JSON 数据格式传输数据。如前端向后端发送运动查询请求时,将查询条件(如运动类型、时间范围等)封装成 JSON 格式发送,后端处理后返回结果,前端依此渲染页面。同时,在用户注册、登录、信息修改等交互流程中,严格遵循 HTTP 协议与数据格式规范,确保前后端交互安全、稳定、高效。
核心代码
package com.example.controller;
import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.SecureUtil;
import com.example.common.Result;
import com.example.common.ResultCode;
import com.example.entity.Caiwu;
import com.example.exception.CustomException;
import com.example.service.CaiwuService;
import com.example.utils.MapWrapperUtils;
import com.example.utils.jwt.JwtUtil;
import com.example.vo.CaiwuVo;
import org.springframework.beans.BeanUtils;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@RestController
@RequestMapping(value = "/caiwu")
public class CaiwuController {
@Resource
private CaiwuService caiwuService;
@PostMapping
public Result<Caiwu> add(@RequestBody CaiwuVo caiwu) {
caiwuService.add(caiwu);
return Result.success(caiwu);
}
@PostMapping("/deleteList")
public Result<Caiwu> deleteList(@RequestBody CaiwuVo caiwu) {
caiwuService.deleteList(caiwu.getList());
return Result.success();
}
@DeleteMapping("/{id}")
public Result delete(@PathVariable Long id) {
caiwuService.delete(id);
return Result.success();
}
@PutMapping
public Result update(@RequestBody CaiwuVo caiwu) {
caiwuService.update(caiwu);
return Result.success();
}
@GetMapping("/{id}")
public Result<Caiwu> detail(@PathVariable Integer id) {
Caiwu caiwu = caiwuService.findById(id);
return Result.success(caiwu);
}
@GetMapping
public Result<List<Caiwu>> all() {
return Result.success(caiwuService.list());
}
@PostMapping("/page")
public Result<CaiwuVo> page(@RequestBody CaiwuVo caiwuVo) {
return Result.success(caiwuService.findPage(caiwuVo));
}
@PostMapping("/login")
public Result login(@RequestBody Caiwu caiwu, HttpServletRequest request) {
if (StrUtil.isBlank(caiwu.getZhanghao()) || StrUtil.isBlank(caiwu.getMima())) {
throw new CustomException(ResultCode.PARAM_LOST_ERROR);
}
Caiwu login = caiwuService.login(caiwu);
// if(!login.getStatus()){
// return Result.error("1001","状态限制,无法登录系统");
// }
if(login != null) {
HashMap hashMap = new HashMap();
hashMap.put("user", login);
Map<String, Object> map = MapWrapperUtils.builder(MapWrapperUtils.KEY_USER_ID,caiwu.getId());
String token = JwtUtil.creatToken(map);
hashMap.put("token", token);
return Result.success(hashMap);
}else {
return Result.error();
}
}
@PutMapping("/updatePassword")
public Result updatePassword(@RequestBody Caiwu info, HttpServletRequest request) {
Caiwu caiwu = caiwuService.findById(info.getId());
String oldPassword = SecureUtil.md5(info.getMima());
if (!oldPassword.equals(caiwu.getMima())) {
return Result.error(ResultCode.PARAM_PASSWORD_ERROR.code, ResultCode.PARAM_PASSWORD_ERROR.msg);
}
info.setMima(SecureUtil.md5(info.getNewPassword()));
Caiwu caiwu1 = new Caiwu();
BeanUtils.copyProperties(info, caiwu1);
caiwuService.update(caiwu1);
return Result.success();
}
}
系统效果图