文章目录
系统演示录像
文章底部名片,联系我获取更详细的演示视频
系统实际运行效果图
技术框架
SpringBoot - 后端开发框架
SpringBoot 是基于 Spring 的快速开发框架,简化了复杂的配置和依赖管理,帮助开发者快速构建稳定、高效的后端服务。它的核心特点包括:
自动配置:通过约定优于配置的理念,简化项目初始化配置。
内嵌服务器:内置如 Tomcat 的服务器,支持独立运行,无需额外部署。
丰富的生态:集成了数据库访问(如 JPA、MyBatis)、安全框架(Spring Security)、分布式服务(Spring Cloud)等功能,满足多种场景需求。
RESTful API 支持:轻松构建标准的 REST 接口,方便与前端进行交互。
Vue - 前端开发框架
Vue 是一款轻量、渐进式的前端框架,适合构建动态的用户界面和单页应用(SPA)。它的核心特点包括:
双向绑定:基于 MVVM 模式,数据驱动视图更新,降低开发复杂度。
组件化开发:将页面功能模块化,提升代码复用性和维护性。
路由和状态管理:借助 Vue Router 和 Vuex,轻松实现页面跳转和全局状态管理。
生态完善:与 Element Plus、Ant Design Vue 等 UI 组件库高度兼容,快速搭建高质量界面。
前后端分离的开发流程
数据接口设计:后端使用 SpringBoot 提供 RESTful 接口,定义好数据模型与响应格式。
前端页面构建:Vue 负责实现页面展示、动态交互,并通过 Axios 等库发送 HTTP 请求与后端通信。
接口联调:前后端通过统一的接口标准(如 JSON)完成数据交互与功能对接。
独立部署:前端打包后可以部署到静态资源服务器(如 Nginx),后端部署在应用服务器上(如 SpringBoot 内嵌 Tomcat)。
可行性分析
可行性分析是每开发一个项目必不可少的一部分,可行性分析可以直接影响一个系统的存活问题,针对开发意义进行分析,还有就是是否可以通过所开发的系统来弥补传统手工统计模式的不足,是否能够更好的解决阿博图书馆管理系统存在的问题等,通过对该阿博图书馆管理系统的开发设计,不仅能够逐步减少工作人员的工作量,而且还可以进行高效工作和管理。所以该系统的开发实现了最大的意义和价值,在系统完成后,利益是否大过于成本,是否能够达到预期效果,这些方面都要进行可行性分析,再通过分析之后,就可以决定是否开发此系统。该阿博图书馆管理系统的开发设计中,以下几点进行了可行性分析:技术可行性:通过Java技术的采用,由于该技术不断成熟,所以使用该技术设计阿博图书馆管理系统是具有可行性的。经济可行性:在开发过程中,系统完成后的利益是否大过于开发成本。操作可行性:阿博图书馆管理系统的开发设计中,方便用户的可操作性和实用性。
系统测试
系统测试是软件开发生命周期中的一个关键阶段,旨在验证整个软件系统在集成后是否满足最初的设计要求和预期功能。它是软件测试中最全面的一种测试类型,涵盖了系统的各个方面,包括功能、性能、安全性、可靠性等。
系统测试的目的
系统测试的目的是在软件开发生命周期的后期阶段,对整个系统进行全面的评估,以确保它符合预期的需求和质量标准。具体来说,系统测试的目的包括以下几个方面:1. 验证功能完整性,系统测试的主要目标是验证系统的所有功能是否按预期工作。这包括检查每个功能模块、各模块之间的交互、输入输出的处理、以及用户界面的响应,以确保系统在功能上符合需求规格说明书的要求。2. 发现缺陷,系统测试通过模拟各种使用场景和操作,发现系统中的潜在缺陷和错误。这些缺陷可能包括功能性问题、性能问题、兼容性问题、或者安全漏洞。通过系统测试,能够在软件发布前发现和修复这些问题,避免在生产环境中出现重大故障。3. 确保系统集成,系统测试验证各个模块和子系统在集成后的整体表现。即使各个模块在单元测试和集成测试中表现正常,系统测试仍然需要确保这些模块在整个系统环境中的协同工作没有问题。
系统功能测试
系统功能测试是系统测试的一部分,主要关注验证软件系统的功能是否符合需求规格说明书中的描述。其目的是确保系统的每个功能模块、组件和子系统都能够按照预期执行,并且各个功能模块之间的交互正确无误。
输入数据 | 预期结果 | 实际结果 | 结果分析 |
---|---|---|---|
用户名:guanliyuan 密码:123456 验证码:正确输入 | 登入系统 | 成功登入系统 | 和估算结果一样 |
用户名:guanliyuan 密码:111111 验证码:正确输入 | 密码错误 | 密码错误,请重新输入密码 | 和估算结果一样 |
用户名:guanliyuan 密码:123456 验证码:错误输入 | 验证码错误 | 验证码信息错误 | 和估算结果一样 |
用户名:空 密码:123456 验证码:正确输入 | 用户名必填 | 请输入用户名 | 和估算结果一样 |
用户名:guanliyuan 密码:空 验证码:正确输入 | 密码错误 | 密码错误,请重新输入密码 | 和估算结果一样 |
用户管理功能测试方案:用户管理主要有添加、编辑、删除、查找用户功能。添加用户时,必填项不填,检验系统是否有非空检验;添加已有的用户信息,检验是否提示用户名已被使用;删除用户信息,系统将检验是否进行此操作;更改用户信息,更改用户信息后页面是否可以展示出来。用户管理测试用例如下表所示。
输入数据 | 预期结果 | 实际结果 | 结果分析 |
---|---|---|---|
填入用户基本信息 | 添加成功,在用户列表中显示 | 该用户出现在在列表中 | 和估算结果一样 |
修改用户信息 | 编辑成功,修改信息成功被修改 | 用户信息被修改 | 和估算结果一样 |
选中删除用户 | 系统询问是否删除用户,确认后用户被删除 | 系统询问是否删除用户,确认后查找不到用户信息 | 和估算结果一样 |
添加用户时不填用户名 | 提示用户名不能为空 | 提示用户名不能为空 | 和估算结果一样 |
填入已有用户名 | 添加失败,提示用户名重复 | 添加失败,提示用户名重复 | 和估算结果一样 |
数据库表设计(供参考)
1. 用户表(t_user)
- 描述: 存储用户的基本信息
- 字段:
字段名 数据类型 主键 是否为空 描述 user_id BIGINT 是 否 用户ID(唯一标识) username VARCHAR(50) 否 否 用户名 password VARCHAR(255) 否 否 密码 email VARCHAR(100) 否 否 邮箱 phone VARCHAR(20) 否 是 电话号码 status TINYINT 否 否 状态(0-禁用,1-启用) create_time DATETIME 否 否 创建时间 update_time DATETIME 否 否 更新时间
2. 角色表(t_role)
- 描述: 存储角色信息
- 字段:
字段名 数据类型 主键 是否为空 描述 role_id BIGINT 是 否 角色ID(唯一标识) role_name VARCHAR(50) 否 否 角色名称 description VARCHAR(255) 否 是 角色描述 create_time DATETIME 否 否 创建时间 update_time DATETIME 否 否 更新时间
3. 权限表(t_permission)
- 描述: 存储权限信息
- 字段:
字段名 数据类型 主键 是否为空 描述 permission_id BIGINT 是 否 权限ID(唯一标识) permission_name VARCHAR(50) 否 否 权限名称 permission_code VARCHAR(50) 否 否 权限编码 description VARCHAR(255) 否 是 权限描述 create_time DATETIME 否 否 创建时间 update_time DATETIME 否 否 更新时间
4. 用户-角色关联表(t_user_role)
- 描述: 记录用户与角色的关联关系
- 字段:
字段名 数据类型 主键 是否为空 描述 id BIGINT 是 否 主键ID user_id BIGINT 否
代码参考
@GetMapping("page")
public ApiRes page() {
ApplyRefundDeposit reqParams = getObject(ApplyRefundDeposit.class);
LambdaQueryWrapper<ApplyRefundDeposit> lambdaQueryWrapper = new LambdaQueryWrapper();
lambdaQueryWrapper.eq(StringUtils.isNotBlank(reqParams.getMchNo()), ApplyRefundDeposit::getMchNo, reqParams.getMchNo());
lambdaQueryWrapper.eq(StringUtils.isNotBlank(reqParams.getMerchantName()), ApplyRefundDeposit::getMerchantName, reqParams.getMerchantName());
lambdaQueryWrapper.eq(StringUtils.isNotBlank(reqParams.getChannelNo()), ApplyRefundDeposit::getChannelNo, reqParams.getChannelNo());
lambdaQueryWrapper.eq(null != reqParams.getApplyState(), ApplyRefundDeposit::getApplyState, reqParams.getApplyState());
lambdaQueryWrapper.orderByDesc(ApplyRefundDeposit::getApplyTime);
// 时间范围条件,1查询申请时间,2查询处理时间
String timeType = reqParams.buildTimeType();
if ("1".equals(timeType)) {
Date[] queryDateRangeArray = reqParams.buildQueryDateRange();
if (queryDateRangeArray[0] != null) {
lambdaQueryWrapper.ge(ApplyRefundDeposit::getApplyTime, queryDateRangeArray[0]);
}
if (queryDateRangeArray[1] != null) {
lambdaQueryWrapper.le(ApplyRefundDeposit::getApplyTime, queryDateRangeArray[1]);
}
} else {
Date[] queryDateRangeArray = reqParams.buildQueryDateRange();
if (queryDateRangeArray[0] != null) {
lambdaQueryWrapper.ge(ApplyRefundDeposit::getProcessTime, queryDateRangeArray[0]);
}
if (queryDateRangeArray[1] != null) {
lambdaQueryWrapper.le(ApplyRefundDeposit::getProcessTime, queryDateRangeArray[1]);
}
}
return ApiRes.ok(applyRefundDepositService.page(getIPage(true), lambdaQueryWrapper));
}
数据库脚本
CREATE TABLE `yonghu` (
`id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键',
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`yonghuming` varchar(200) NOT NULL COMMENT '用户名',
`mima` varchar(200) NOT NULL COMMENT '密码',
`xingming` varchar(200) DEFAULT NULL COMMENT '姓名',
`xingbie` varchar(200) DEFAULT NULL COMMENT '性别',
`touxiang` varchar(200) DEFAULT NULL COMMENT '头像',
`shouji` varchar(200) DEFAULT NULL COMMENT '手机',
`shenfenzheng` varchar(200) DEFAULT NULL COMMENT '身份证',
PRIMARY KEY (`id`),
UNIQUE KEY `yonghuming` (`yonghuming`)
) ENGINE=InnoDB AUTO_INCREMENT=1616222324596 DEFAULT CHARSET=utf8mb3 COMMENT='用户';
CREATE TABLE `messages` (
`id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键',
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`userid` bigint NOT NULL COMMENT '留言人id',
`username` varchar(200) DEFAULT NULL COMMENT '用户名',
`content` longtext NOT NULL COMMENT '留言内容',
`reply` longtext COMMENT '回复内容',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1616222424131 DEFAULT CHARSET=utf8mb3 COMMENT='留言板';
CREATE TABLE `token` (
`id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键',
`userid` bigint NOT NULL COMMENT '用户id',
`username` varchar(100) NOT NULL COMMENT '用户名',
`tablename` varchar(100) DEFAULT NULL COMMENT '表名',
`role` varchar(100) DEFAULT NULL COMMENT '角色',
`token` varchar(200) NOT NULL COMMENT '密码',
`addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '新增时间',
`expiratedtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '过期时间',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb3 COMMENT='token表';
找我做程序,有什么保障?
我本人就是科技工作室负责人,程序大部分由博主亲自带领主导开发完成,页面设计、接口设计多由博主个人为广大需求者定制开发,如果需要其他功能,也可以联系我进行定制开发,找我们做的程序项目,都享有代码讲解服务,会议博主亲自讲解,可以全程录音录屏!这就是我们的保障,团队开发让您更省心省力,得到更大的保障!!!
联系我们
大家点赞、收藏、关注、评论 啦
标签:COMMENT,vue,SpringBoot,DEFAULT,系统,用户,2024,用户名,NULL From: https://blog.csdn.net/weixin_44952775/article/details/144376564
查看