家庭财务管理系统 - 答辩文档一、项目概述1.1 项目名称FFMSFamily Financial Management System- 家庭财务管理系统1.2 项目背景随着家庭经济活动的日益复杂家庭成员的收入支出、理财投资、负债管理等财务信息需要一个系统化的管理平台。本系统旨在帮助家庭实现财务信息的集中管理、统计分析提高家庭财务管理效率和透明度。1.3 项目目标实现家庭收支账单的数字化记录与管理支持多用户协作区分家庭成员角色权限提供资产总览、负债管理、理财推荐等功能生成统计报表辅助家庭财务决策1.4 技术栈技术分类采用技术后端框架Spring Boot 2.4.5持久层框架MyBatis 1.3.2数据库MySQL 8.0前端模板Thymeleaf前端框架Layui构建工具MavenJava版本JDK 1.8二、核心功能模块2.1 用户管理模块用户注册/登录支持用户注册和登录密码采用MD5加密存储角色权限管理三种角色系统管理员、家庭管理员、普通用户家庭成员管理家庭管理员可管理家庭成员信息密码修改支持用户修改个人密码2.2 收支管理模块收入记录记录工资、奖金、兼职等各类收入支出记录记录日常开销、购物、医疗等支出账单查询支持按时间、金额、支付方式等条件筛选月度统计按月份汇总收支情况2.3 账户总览模块活期资产查看家庭活期资产余额理财详情管理理财产品记录负债详情记录房贷、贷款等负债信息理财推荐根据风险等级推荐理财产品2.4 理财管理模块理财记录记录银行存储、基金、股票、黄金等投资收益统计统计理财收益情况理财对比对比不同理财方式的收益2.5 统计报表模块收支趋势图展示收支变化趋势分类统计按类别统计收支占比数据可视化使用图表直观展示财务数据2.6 系统管理模块用户管理管理系统用户系统管理员权限角色管理维护角色及其权限配置权限分配为角色分配菜单访问权限三、系统架构3.1 架构设计采用经典的三层架构模式┌─────────────────────────────────────┐ │ Presentation Layer │ │ (Thymeleaf Layui REST API) │ ├─────────────────────────────────────┤ │ Business Layer │ │ (Controller Service) │ ├─────────────────────────────────────┤ │ Data Access Layer │ │ (MyBatis Mapper MySQL) │ └─────────────────────────────────────┘3.2 项目结构ffms/ ├── src/main/java/com/xust/ffms/ │ ├── FfmsApplication.java # 启动类 │ ├── configs/ # 配置类 │ │ ├── CorsConfig.java # 跨域配置 │ │ ├── SessionInterceptor.java # 会话拦截器 │ │ └── Md5UtilSimple.java # MD5加密工具 │ ├── controller/ # 控制器层 │ │ ├── UserInfoController.java # 用户管理 │ │ ├── BillController.java # 账单管理 │ │ ├── LicaiController.java # 理财管理 │ │ ├── CuraccountController.java # 活期账户 │ │ ├── DebtController.java # 负债管理 │ │ └── MoneyManageController.java# 理财推荐 │ ├── service/ # 服务层接口 │ │ └ impl/ # 服务层实现 │ ├── dao/ # 数据访问层 │ │ ├── UserInfoMapper.java │ │ ├── BillMapper.java │ │ ├── LicaiMapper.java │ │ └── ... │ ├── entity/ # 实体类 │ │ ├── UserInfo.java │ │ ├── Bill.java │ │ ├── Licai.java │ │ ├── Curaccount.java │ │ ├── Debt.java │ │ ├── Product.java │ │ ├── Privilege.java │ │ └── Role.java │ └── utils/ # 工具类 │ ├── Config.java # 系统配置常量 │ ├── Result.java # 统一响应封装 │ ├── ResultUtil.java # 响应工具类 │ ├── PageModel.java # 分页模型 │ └── Utils.java # 通用工具 ├── src/main/resources/ │ ├── application.yml # 应用配置 │ ├── mappers/ # MyBatis映射文件 │ │ ├── UserInfoMapper.xml │ │ ├── BillMapper.xml │ │ ├── LicaiMapper.xml │ │ └── ... │ ├── templates/ # Thymeleaf模板 │ └── static/ # 静态资源 ├── sql/ │ ├── ffms.sql # 数据库脚本 │ └── ffms_sys.sql # 系统数据脚本 └── pom.xml # Maven配置四、数据库设计4.1 数据库概览数据库ffms_sysMySQL 8.04.2 核心数据表表名功能说明user用户信息表role角色表privilege权限表roleprivilieges角色-权限关联表house家庭表bill账单表type收支类型表payway支付方式表curaccount活期资产表debt负债表licai理财记录表licaiway理财方式表moneymanage理财推荐表product理财产品表4.3 主要表结构用户表(user)字段名类型说明idint主键自增usernamevarchar(255)登录账号passwordvarchar(255)密码MD5加密realnamevarchar(255)真实姓名roleidint角色编号外键houseidint所属家庭编号外键photovarchar(255)用户头像账单表(bill)字段名类型说明idint主键自增titlevarchar(255)账单标题useridint用户ID外键moneyfloat(10,2)金额typeidint类型1支出2收入remarkvarchar(255)备注paywayidint支付方式ID外键timedatetime交易时间理财记录表(licai)字段名类型说明idint主键自增titlevarchar(255)理财标题useridint用户IDmoneyfloat(99,2)金额typeidint类型3收入4支出licaiwayidint理财方式IDtimedatetime交易时间4.4 ER关系图┌────────┐ ┌────────┐ ┌──────────────┐ │ user │────▶│ role │────▶│roleprivilieges│ └────────┘ └────────┘ └──────────────┘ │ │ │ ▼ │ ┌──────────┐ │ │privilege │ │ └──────────┘ ▼ ┌────────┐ ┌────────┐ │ house │◀────│ bill │ └────────┘ └────────┘ │ │ ▼ ▼ ┌──────────┐ ┌────────┐ ┌────────┐ │curaccount│ │ payway │ │ type │ └──────────┘ └────────┘ └────────┘五、角色权限设计5.1 角色定义角色ID角色名称权限范围1系统管理员全系统权限包括用户管理、角色管理2家庭管理员管理本家庭所有成员和财务信息3普通用户仅查看和管理个人财务信息5.2 权限菜单权限编号权限名称菜单级别001收支管理一级菜单001001收入详情二级菜单001002支出详情二级菜单002账户总览一级菜单002001活期资产二级菜单002002理财详情二级菜单002003负债详情二级菜单002004理财推荐二级菜单003统计报表一级菜单004家庭成员管理一级菜单005系统管理一级菜单六、答辩问答要点6.1 技术相关问题Q1: 为什么选择Spring Boot作为后端框架Spring Boot简化了Spring应用的配置提供自动配置机制内置Tomcat服务器无需部署WAR包即可运行与MyBatis整合方便开发效率高适合快速开发中小型项目Q2: 项目如何实现用户权限控制采用RBAC基于角色的访问控制模型用户-角色-权限三级关联SessionInterceptor拦截器验证用户登录状态根据用户角色动态加载菜单权限Q3: MyBatis相比Hibernate有什么优势SQL语句灵活适合复杂查询场景支持动态SQL便于多条件查询与数据库交互更直接性能可控学习成本低配置简单Q4: 前端采用什么技术方案Thymeleaf模板引擎实现页面渲染Layui前端框架提供UI组件RESTful API与后端交互AJAX实现异步数据加载6.2 业务相关问题Q5: 系统如何区分家庭成员的数据权限家庭管理员roleid2可查看全家财务数据普通用户roleid3仅能查看个人数据通过houseid字段关联家庭成员查询时根据角色动态设置过滤条件Q6: 账单添加时如何同步更新活期资产BillServiceImpl的add方法中自动更新Curaccount收入时增加活期资产支出时减少活期资产若用户无活期资产记录则自动创建保证数据一致性Q7: 理财推荐功能如何实现Product表存储理财产品信息包含风险等级R1-R5、风险描述、亏损概率用户可根据风险偏好选择合适产品支持产品增删改查管理Q8: 统计报表的数据来源是什么从bill表和licai表聚合统计数据按时间范围、收支类型分组查询使用MyBatis的聚合函数SUM、COUNT返回JSON数据供前端图表渲染6.3 安全相关问题Q9: 系统如何保证用户密码安全密码采用MD5加密存储登录验证时对比加密后的密文不在响应中返回密码信息支持密码修改功能Q10: 如何防止未登录用户访问系统SessionInterceptor拦截所有请求检查Session中是否存在用户信息未登录则重定向到登录页面支持Cookie实现短期免登录6.4 项目亮点角色权限设计完善三级角色体系满足不同用户需求数据权限隔离家庭数据与个人数据隔离清晰资产联动更新账单与活期资产自动同步理财推荐功能提供风险分级的产品推荐统计图表展示直观呈现财务数据分析结果七、系统运行说明7.1 环境要求JDK 1.8MySQL 8.0Maven 3.x7.2 启动步骤创建数据库并导入sql/ffms_sys.sql修改application.yml中的数据库连接配置执行mvn spring-boot:run启动项目访问http://localhost:8080进入系统7.3 默认账号账号密码角色admin123456系统管理员mother123456家庭管理员八、总结本项目是一个完整的家庭财务管理解决方案涵盖了收支管理、资产管理、理财管理、统计分析等核心功能。系统采用Spring BootMyBatisThymeleaf技术栈实现了用户权限控制、数据隔离、资产联动等关键特性适合家庭财务管理场景的实际应用。