摘 要
农机配件仓库管理系统的目的是让使用者可以更方便的将人、设备和场景更立体的连接在一起。能让用户以更科幻的方式使用产品,体验高科技时代带给人们的方便,同时也能让用户体会到与以往常规产品不同的体验风格。
与安卓,iOS相比较起来,农机配件仓库管理系统在流畅性,续航能力,等方方面面都有着很大的优势。这就意味着农机配件仓库管理系统的设计可以比其他系统更为出色的能力,可以更高效的完成最新的产品信息及商品的采购、入库、出库、供应商等功能。
此系统设计主要采用的是JAVA语言来进行开发,采用Spring Boot框架技术,框架分为三层,分别是控制层Controller,业务处理层Service,持久层dao,能够采用多层次管理开发,对于各个模块设计制作有一定的安全性;数据库方面主要采用的是MySQL来进行开发,其特点是稳定性好,数据库存储容量大,处理能力快等优势;服务器采用的是Tomcat服务,能够提供稳固的运行平台,确保系统稳定运行。通过农机配件仓库管理系统来提升本课题的各项功能的工作效率,提供了一个多样功能,具有良好实用性的农机配件仓库管理系统。
关键词:农机配件仓库管理系统;Spring Boot框架;JAVA语言;
Abstract
The purpose of the agricultural machinery parts warehouse management system is to make it easier for users to connect people, equipment, and scenes in a more three-dimensional manner. It can enable users to use products in a more sci-fi manner, experience the convenience brought by the high-tech era, and also enable users to experience a different experience style from traditional products.
Compared to Android and iOS, the agricultural machinery parts warehouse management system has great advantages in terms of smoothness, endurance, and other aspects. This means that the design of the agricultural machinery parts warehouse management system can have more excellent capabilities than other systems, and can more efficiently complete the latest product information and functions such as purchasing, warehousing, outbound, and supplier of goods.
This system design mainly uses JAVA language for development, using Spring Boot framework technology. The framework is divided into three layers, namely, the control layer Controller, the business processing layer Service, and the persistence layer dao. It can adopt multi-level management development, and has certain security for the design and production of various modules; MySQL is mainly used for database development, characterized by good stability, large database storage capacity, and fast processing capabilities; The server uses Tomcat services, which can provide a stable operating platform and ensure stable operation of the system. Through the agricultural machinery parts warehouse management system to improve the efficiency of various functions of this topic, it provides a diversified and practical agricultural machinery parts warehouse management system.
Key words: agricultural machinery parts warehouse management system; Spring Boot framework; JAVA Language;
目 录
摘 要 I
Abstract II
1 绪 论 1
1.1研究意义 1
1.2系统设计目的 2
1.3系统设计思想 2
2系统需求分析 3
2.1系统性能需求 3
2.2系统用例图 3
2.3可行性分析 4
2.3.1经济可行性 4
2.3.2技术可行性 5
2.3.3社会可行性 6
2.4系统开发技术 6
2.4.1 springboot框架 7
2.4.2 B/S架构 8
2.4.3 MySQL介绍 8
2.4.4 Java介绍 9
2.5系统流程分析 10
3系统设计 11
3.1系统功能结构 12
3.1.1系统结构图 13
3.2数据库设计 15
3.2.1 数据库概念设计 16
3.2.2数据逻辑结构 18
4系统详细设计 21
4.1登录模块设计 22
4.2管理员功能模块 23
4.3采购员功能模块 24
4.4销售员功能模块 25
4.5仓管员功能模块 26
5 软件测试 28
5.1软件测试原则 29
5.2测试用例 30
结 论 30
参考文献 31
致 谢 32
1 绪 论
近些年来,随着电子科学技术的高速发展,计算机相关行业的发展创新。衍生出了各种各样方便快捷的电子设备。如手机,电脑等。这些电子设备功能强大,方便所有类型的人们使用。但这些年来,人们对手机,电脑等电子高科技产物的依赖和需求也越来越大。现在的人们已经不再满足于它们各式各样的基础功能,例如与他人通讯,上网了解信息等[1]。人们现在更希望的是随着科技的发展,手机、电脑等高科技产品可以给自己带来更多方便快捷、简单实用的功能。同时也希望自己在使用的时候可以更轻松的掌握使用这些设备的技巧。同时,伴随着这些电子设备的出现,操作系统就显的尤为重要,电子设备各式各样功能的顺利运行都要依靠它的稳定运行。操作系统可以管理、控制计算机的硬件资源和软件资源,也是计算机最为基本的系统软件。人们所有能涉及到和使用到的软件运行几乎都离不开它。它就像人类的大脑一样,控制着计算机的各种设备。但同样,操作系统在发展时自身也会出现很多问题,同样的系统不能应用在所有的硬件设备上。这个问题对于大部分的电子科技受益者来说很陌生,处理起来很有困难。会让使用者不能在第一时间使用,因此会造成很多负面的影响[2]。
什么是农机配件仓库管理系统?农机配件仓库管理系统区别于人们司空见惯的安卓系统和iOS系统,农机配件仓库管理系统希望只用一整套系统就解决使用的硬件设备需要有不同的系统的繁琐问题。它的出现不仅让使用者在使用时更加方便,还可以让使用者在使用选项上有了更多选择的余地。农机配件仓库管理系统十分流畅,可以让使用者在使用时几乎没有任何的延迟和卡顿,可以给使用者带来十分轻松的体验。并且可以在几乎我们能看到的所有电子设备上使用,大幅度的增加了农机配件仓库管理系统的使用范围。同时,农机配件仓库管理系统可以同步全部的连接对象,对于使用者来说这样的系统更加方便。它可以很精准的将使用者所需的各方面的农机配件仓库需求通过该系统提供给使用者,并且它的使用普遍性可以让各个年龄段的使用者都能有一个良好的使用体验[3]。
1.1研究意义
伴随着科技的进步,时代的发展,越来越多的电子设备也随之出现在人们的眼前,在电子设备,软件技术成熟之前,人们可以选择使用电子设备,通过仓库管理软件的帮助,找到最适合自己,最符合自己的管理方式。而农机配件仓库的普及也伴随着很多问题,有的仓库管理软件不能适应用户使用的电子设备的系统,这会让部分使用者对这款软件彻底否认,会导致该系统失去预想的市场竞争力,面临淘汰。使用者更希望自己使用的农机配件仓库管理系统可以在完成最基本的功能需求的基础上变的更加稳定,流畅,并且没有任何因兼容性而引发的复杂问题[4]。
而农机配件仓库管理系统的出现也渐渐让这种类似的问题有了一个相对明确的解决方案,农机配件仓库管理系统可以使软件的运行速度变的更快,并且可以同步全部的连接对象,可以确保项目的正确运行,同时,在如此信息化的时代里,使用者对软件的各项要求也越来越多,在如此广阔的信息量之下,使用者更希望自己使用的系统可以畅通无阻的浏览每个网页上的信息,可以全方位的了解产品信息、销售订单、采购信息等的特点,根据自己的需求,选择最适合自己的方案。并且让整个电子信息时代都注入了新鲜的血液,且能更好的流向各个领域,各个行业,为电子信息时代继续发光发热[5]。
1.2系统设计目的
为了适应电子信息时代和科技化时代的到来,并且应对今后可能越来越广泛的信息化的发展,需要做出了更加超前时代的功能应对。在这个高速发展的时代里,使用者对信息管理系统的要求也是越来越高,使用者都希望自己可以有拥有一款符合当今科技发展时代,且具有科技感,功能齐全的系统。希望可以只通过一个系统就可以轻松完成自己的需求,而不再因为信息的复杂而不知如何做出最佳选择。科技时代带给了人们轻松,立体的体验,而农机配件仓库管理系统就符合大家对科技时代的系统所拥有的期待,它可以提升用户的使用体验[6]。
1.3系统设计思想
想要做一个完整的系统,就必须要为其制定一套详细并且规范的原则。这些原则定可以帮助我们在设计过程中能有一个更好的设计理念和设计方向,可以让系统变的更加立体,更加完美[7]。变成更加符合使用者所希望的模样。所以为了能够更好的完成系统,对系统制定了一些原则:
(1)以人为本原则
这个农机配件仓库管理系统,它的本质是为人们服务。是希望其可以实现并满足广大使用者对科技时代下的农机配件仓库管理系统的憧憬与向往。如何解放需要人工才能完成的部分和提升使用者的使用观感是最为基础的也是最重要的。它的设计宗旨就是为使用者服务。明确使用者的想法和需求,设法让使用者可以真实的感受到科技时代的魅力是设计的初衷。农机配件仓库管理系统可以满足新时代使用者的需求,让使用者能够真实的感受到它的便捷。
(2)可修改原则
设计系统时并不能确保让所有的功能都达到使用者最理想的要求,在设计的过程中可能会有纰漏。所以在设计时要确保可以及时对不完整,不完美的部分进行修改和补充。同时,也要确保在系统发行后,在出现bug时可以在不影响使用者使用的情况下对系统进行线上维护。同时要确保在修复,更新,维护的同时可以保证使用者的体验[8]。
2系统需求分析
需求分析的首要是要分析用户的需求,知道用户存在的一些情况,并且要明确用户的使用状况,然后设计规划解决的问题[9]。其中在使用定性的分析以及定量的分析,从这两个方面获取用户的需求。一方面定性的分析获得的应该是用户的基本需求,能够发现现在人们的习惯要求。所以定性的需要主要是为了多与用户交流,从而更为深刻的了解一些存在的需求问题;定量的分析则是发现一些潜在的用户,并且获得不一样的反馈内容。所以定量的需求要让用户来阐述一些情况,一定让使用者清晰的进行客观的描述,这样才能够比较全面的获得用户的需求所在。
2.1系统性能需求
(1)鉴于该系统是一款面向全体使用者的系统,管理者需要录入使用者的个人信息、给予使用者应有的权限,让使用者可以更加自由的使用系统。
(2)要给予用户更高的查询权限,让用户可以全方位的了解本课题,让用户可以查询到产品信息、公告栏等。
(3)要提升用户的使用效率,让用户可以更加快捷的查询自己想要查询的东西。同时,还要做到同步性,在用户查询信息或者修改信息的同时,系统可以及时反馈到数据库上,进行及时更新和修复[10]。
2.2系统用例图
本系统采用自上往下的方法开发,基本定位如下功能:
本课题要求实现一套基于Spring Boot的农机配件仓库管理系统的设计与实现,系统主要包括管理员模块和采购员 、销售员、仓管员模块的功能模块;
(1)管理员用例图如下所示:
图2-1管理员用例图
(2)仓管员用例图如下所示:
图2-2仓管员用例图
(3)采购员用例图如下所示:
图2-3采购员用例图
(4)销售员用例图如下所示:
图2-4销售员用例图
2.3可行性分析
2.3.1经济可行性
任何系统在开发之前,经济方面的问题都是最应该被考虑的,经济问题主要体现在两个方面。一方面是在开发时,现有可使用的设计资源能否满足系统的预计开发消耗;另一方面是在开发以后,系统的盈利能否保证系统的正常运行和日复一日的更新消耗。
开发方面,因为在开发系统时使用的开发工具基本都是免费的,只有一些少量的人工费。所以,开发工具上的经济消耗都是很少的,都是在可控范围内的。另外,可以在确保质量的前提下,尽可能的减少设计成本,可以为开发之后的工作留下更多的经济资源。
在最大限度降低开发成本的同时,也可以让使用者最大限度的从系统中获利,对双方来说都是一个可行的农机配件仓库管理系统。总结下来就是,该系统的各项开发费用都处于可控范围内。经过了种种分析和考虑后证明,该系统软件可以行得通的,经济方面的压力是在预料之内的。
2.3.2技术可行性
在研究技术可行性的时候,系统的开发环境是可以确定的,所以技术可行性最好与系统功能和性能以及一些实际的情况同时考虑。在可行性研究阶段,结合实际调整开发的内容和选择能够完成的技术体系是一个可用的手段,如果系统进入开发阶段,任何的调整都意味着会耗费更多的经历。需要再次明确的问题是,技术可行性不只是考虑在技术上是否可实现,实际上还包含了在当前的实际的情况下的技术可行性。有很多的因素例如时间不足、预期的开发目标技术难度比较难、不能有充足的技术积累、而且对于技术的掌握不够等这些实际存在的情况,都是要提前部署和认真规划的。
开发农机配件仓库管理系统的技术内容分析,目前的状况是从网络硬件和相关技术上看是可行的。该系统采用了JAVA和 MySQL技术。到现在可以知道,很多的基础知识都是经过学习使用的,在后续的设计中还需要不断的练习,学习更多相关的技术经验来充实自己对于系统的开发。
2.3.3社会可行性
在社会可行性分析中,首先能结合国家经济和社会发展的实际情况,还需要能够让用户更加的便利,给使用者带来多方面的高效益,使得可以比较快速的发展以及应用,随着很多领域的发展,尤其是智能化的社会下,据统计许多的人都拥有属于自己的系统,这种情况下就带来很多的问题,比较突出的就是管理上的不足,从而出现低效率的原因。
在可行性分析中的收益分析,是比较清晰地发掘开发的系统带来的各种直接的有效的利益以及一些隐藏起来的好处,以便在后续的设计中更加的坚定和确信系统开发的意义。解决一些社会方面存在的问题,设计并开发系统肯定是要发现某类社会存在的问题,并且能够带来一定的社会价值。还有一些社会的影响力,是通过系统想优势和切实的好处来产生的,能够在一定的情况下提高效率,肯定会增加一些社会的进步和发展。社会上的可行性,包括法律上的可行性,也包括法律上的可能性,法律上的可行性,需要社会上的许多因素,可以来实现系统建设的现实性。如果所开发的系统与国家法律或政策等相关的因素不相符合,在某些信息化的邻域中使用的是一些加密的信息或者技术问题,还有不经过正常的操作使用其他的一些公开的信息等这些情况,这样的系统的开发在法律的范围中就是不能被允许的。
其中还有一个比较重要的用户使用可行性也是通过执行系统时的可行性,是从所有情况下用户的角度来考虑系统的可行性,由于设计开发相关的系统就是站在社会中广大的用户体验考虑的,所以在这个层面考虑也是符合的。
2.4系统开发技术
2.4.1 springboot框架
Spring Boot是近几年最为流行的后台开发框架,它的诞生一改过去Spring框架开发中繁琐的配置,极大地简化了Spring应用的搭建和开发。Spring Boot框架不仅保有了Spring框架中的所有优秀特性,还通过使用特定的配置方式,在底层帮助开发人员在工程创建是就预先做了很多配置,这样在开发时就不再需要开发人员过多进行繁琐的配置了。另外在Spring Boot中集成了大量框架,这就使得开发人员不再需要到处寻找在导入开发中需要依赖的jar包,同时也解决了依赖包版本冲突问题,从而提高了依赖包引用的稳定性,从而实现了对Spring应用搭建和开发过程的简化。
2.4.2 B/S架构
B/S结构就是指系统客户端与服务器分离,客户端通过浏览器访问服务端进行操作。
B/S结构目前广泛应用于绝大部分系统搭建中,这种结构摒弃C/S结构客户端服务端不分离的缺点,具有更多的优势:
(1)跨平台性:B/S的标准由标准化组织确立,适用于绝大多数的系统搭建,通用于应用之间。
(2)低维护成本:客户端和服务器端分离,减轻了两端的压力,尤其是客户端,对客户端设备,硬件、软件要求都比较低,并且系统需要升级或维护时,只需要在服务器端升级或维护就可以,使相应的费用减少。
2.4.3 MySQL介绍
MySQL 是一种关联数据库管理系统,该系统速度快而且灵活性强,主要原因是它将数据保存在不同的表中,MySQL软件的优点是成本低、体积小、速度快,开放源码,所以一般中小型网站的开发都选择 MySQL 作为网站数据库。
2.4.4 Java介绍
Java 最大的两个特点就是功能强大和简单易用。Java可以让程序员进行复杂的编程而不必为储存管理对象等问题所烦恼,把精力和时间更多的放在研发与设计上,极大地提高了开发者的工作效率和工作热情。
2.5系统流程分析
(1)个人信息流程图
用户在成功进入系统以后,可以获得工号、姓名、联系电话等个人信息。获得个人信息的流程见图2-5所示。
图2-5个人信息流程图
用户进行登录操作的流程图如图2-6。
图2-6 用户登录界面流程图
用户进行注册操作的流程图如图2-7。
图2-7 用户注册流程图
3系统设计
系统设计要提出具体的软件功能及要求,是系统分析后进行的流程。它的主要目的是提供软件开发的思路和具体流程,是系统运行的根本保障。它要确定软件各个模块的功能,并形成相应的流程图,方便设计者思考。同时要将每个模块需要完成的任务详细的表达出来,并对每个模块进行具体化的设计分析,提供相当数量的设计方案,再通过设计者的详细分析和比对,选择出最佳的方案进行设计开发。并对相应的方案进行验证和拓展。
3.1系统功能结构
3.1.1系统结构图
系统结构图可以把杂乱无章的模块按照设计者的思维方式进行调整排序,可以让设计者在之后的添加,修改程序内容的过程中有一个很明显的思维方向。同时结构图还可以让设计者以外的其他人更直观的看出整个系统的设计理论和设计过程。让系统的设计变的更直观。该系统的功能架构图如图3-1所示:
图3-1 农机配件仓库管理系统功能结构图
3.2数据库设计
3.2.1 数据库概念设计
从系统运行完整的角度出发,设置相应的实体,明确各实体之间的联系。下面列举整个系统中涉及核心功能的实体:
1、采购员信息实体
图3-2采购员信息实体图
2、销售员信息实体
图3-3销售员信息实体图
3、产品信息实体
图3-4产品信息实体图
4、采购信息实体
图3-5 采购信息实体图
3.2.2数据逻辑结构
在综合了以上对系统的设计,和对数据库的分析,同时结合了以往对数据库的使用经验后,构建了以下几张表,以下为每张表的内容:
表3-1:仓管员
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
cangguangonghao varchar 200 仓管工号
cangguanxingming varchar 200 仓管姓名
mima varchar 200 密码
xingbie varchar 200 性别
xianzhuzhi varchar 200 现住址
lianxidianhua varchar 200 联系电话
表3-2:token表
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
userid bigint 用户id
username varchar 100 用户名
tablename varchar 100 表名
role varchar 100 角色
token varchar 200 密码
addtime timestamp 新增时间 CURRENT_TIMESTAMP
expiratedtime timestamp 过期时间 CURRENT_TIMESTAMP
表3-3:采购员
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
caigougonghao varchar 200 采购工号
caigouxingming varchar 200 采购姓名
mima varchar 200 密码
xingbie varchar 200 性别
zhicheng varchar 200 职称
lianxidianhua varchar 200 联系电话
表3-4:收藏表
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
userid bigint 用户id
refid bigint 商品id
tablename varchar 200 表名
name varchar 200 名称
picture longtext 4294967295 图片
type varchar 200 类型(1:收藏,21:赞,22:踩,31:竞拍参与,41:关注) 1
inteltype varchar 200 推荐类型
remark varchar 200 备注
表3-5:采购信息
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
dingdanbianhao varchar 200 订单编号
chanpinbianhao varchar 200 产品编号
chanpinmingcheng varchar 200 产品名称
chanpinleibie varchar 200 产品类别
pinpai varchar 200 品牌
shuliang int 采购数量
jinhuojia float 进货价
zongjine float 总金额
changjia varchar 200 厂家
baozhiqi varchar 200 保质期
shengchanriqi date 生产日期
caigougonghao varchar 200 采购工号
caigouxingming varchar 200 采购姓名
gongyingshangmingcheng varchar 200 供应商名称
caigoushijian date 采购时间
sfsh varchar 200 是否审核 待审核
shhf longtext 4294967295 审核回复
表3-6:商品入库
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
chanpinbianhao varchar 200 产品编号
chanpinmingcheng varchar 200 产品名称
chanpinleibie varchar 200 产品类别
pinpai varchar 200 品牌
shuliang int 入库数量
cangguangonghao varchar 200 仓管工号
cangguanxingming varchar 200 仓管姓名
rukushijian date 入库时间
表3-7:报损登记
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
chanpinbianhao varchar 200 产品编号
chanpinmingcheng varchar 200 产品名称
chanpinleibie varchar 200 产品类别
pinpai varchar 200 品牌
shuliang int 报损数量
cangguangonghao varchar 200 仓管工号
cangguanxingming varchar 200 仓管姓名
dengjishijian date 登记时间
beizhu varchar 200 备注
表3-8:商品出库
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
chanpinbianhao varchar 200 产品编号
chanpinmingcheng varchar 200 产品名称
chanpinleibie varchar 200 产品类别
pinpai varchar 200 品牌
shuliang int 出库数量
cangguangonghao varchar 200 仓管工号
cangguanxingming varchar 200 仓管姓名
chukushijian date 出库时间
表3-9:客户信息
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
kehumingcheng varchar 200 客户名称
kehudizhi varchar 200 客户地址
kehudianhua varchar 200 客户电话
youxiang varchar 200 邮箱
chuanzhen varchar 200 传真
表3-10:供应商
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
gongyingshangmingcheng varchar 200 供应商名称
gongyingshangdizhi varchar 200 供应商地址
lianxidianhua varchar 200 联系电话
fuzerenxingming varchar 200 负责人姓名
zhiwu varchar 200 职务
zhuxiaochanpin varchar 200 主销产品
表3-11:销售员
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
xiaoshougonghao varchar 200 销售工号
xiaoshouxingming varchar 200 销售姓名
mima varchar 200 密码
xingbie varchar 200 性别
zhicheng varchar 200 职称
lianxidianhua varchar 200 联系电话
表3-12:公告栏
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
gonggaobiaoti varchar 200 公告标题
fabushijian datetime 发布时间
gonggaoneirong longtext 4294967295 公告内容
clicktime datetime 最近点击时间
表3-13:销售订单
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
chanpinbianhao varchar 200 产品编号
chanpinmingcheng varchar 200 产品名称
chanpinleibie varchar 200 产品类别
kehumingcheng varchar 200 客户名称
pinpai varchar 200 品牌
shuliang int 数量
lirun float 利润
zongjine float 总金额
xiaoshougonghao varchar 200 销售工号
xiaoshouxingming varchar 200 销售姓名
xiaoshoushijian date 销售时间
sfsh varchar 200 是否审核 待审核
shhf longtext 4294967295 审核回复
表3-14:配置文件
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
name varchar 100 配置参数名称
value varchar 100 配置参数值
表3-15:物流信息
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
huowumingcheng varchar 200 货物名称
wuliubianhao varchar 200 物流编号
huowutupian longtext 4294967295 货物图片
shuliang int 数量
shoujianren varchar 200 收件人
lianxidianhua varchar 200 联系电话
gengxinshijian datetime 更新时间
wuliugongsi varchar 200 物流公司
wuliuzhuangtai varchar 200 物流状态
luxiangenzong longtext 4294967295 路线跟踪
表3-16:产品信息
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
chanpinbianhao varchar 200 产品编号
chanpinmingcheng varchar 200 产品名称
chanpinleibie varchar 200 产品类别
pinpai varchar 200 品牌
shuliang int 数量
jinhuojia float 进货价
xiaoshoujia float 销售价
lirun float 利润
changjia varchar 200 厂家
baozhiqi varchar 200 保质期
beizhu varchar 200 备注
表3-17:用户表
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
username varchar 100 用户名
password varchar 100 密码
role varchar 100 角色 管理员
addtime timestamp 新增时间 CURRENT_TIMESTAMP
表3-18:产品类别
字段名称 类型 长度 字段说明 主键 默认值
id bigint 主键
主键
addtime timestamp 创建时间 CURRENT_TIMESTAMP
chanpinleibie varchar 200 产品类别
4系统详细设计
4.1登录模块设计
这个功能模块用来让工作人员进行后端登录。管理人员通过网站。在输入自己的用户名和密码、角色进行登录,登录后管理人员就可以对后台的信息相关的操作。
首先,设计后端管理的登陆页面。对页面的各个板块进行详细的设计,规划它们的字体大小,背景颜色,字体颜色和板块大小等。还要加上图片,让页面被设计的更加美观。以便让以后需要登陆的管理员可以直观的使用。
4.2管理员功能模块
管理员通过登录页面填写用户名和密码,完成后进行登录,如图4-1所示。
图4-1管理员登录页面
管理员登录进入农机配件仓库管理系统的实现可以查看系统首页、个人中心、采购员管理、销售员管理、仓管员管理、产品类型管理、产品信息管理、采购信息管理、销售订单管理、商品入库管理、商品出库管理、报损登记管理、供应商管理、客户信息管理、公告栏管理等信息,如图4-2所示。
图4-2管理员功能界面图
管理员点击采购员管理;在采购员管理页面对采购工号、采购姓名、性别、职称、联系电话等信息,进行查询,新增或删除采购员信息等操作;如图4-3所示。
图4-3采购员管理界面图
管理员点击销售员管理;在销售员管理页面对销售工号、销售姓名、性别、职称、联系电话等信息,进行查询,新增或删除销售员信息等操作;如图4-4所示。
图4-4销售员管理界面图
管理员点击仓管员管理;在仓管员管理页面对仓管工号、仓管姓名、性别、现住址、联系电话等信息,进行查询,新增或删除仓管员信息等操作;如图4-5所示。
图4-5仓管员管理界面图
管理员点击产品信息管理;在产品信息管理页面对产品编号、产品名称、产品类别、品牌、数量 、进货价、销售价、厂家、保质期、备注等信息,进行查询或删除产品数量等操作;如图4-6所示。
图4-6产品信息管理界面图
管理员点击采购信息管理;在采购信息管理页面对订单编号、产品编号、产品名称、产品类别、品牌、采购数量、进货价、总金额、厂家、保质期、生产日期、采购工号、采购姓名、供应商名称、采购时间等信息,进行查询或删除采购信息等操作;如图4-7所示。
图4-7采购信息管理界面图
4.3 采购员功能模块
登录界面,首先双击打开系统,连上网络之后会显示出本系统的登录界面,这是进入系统的第初始页面“登录”,能成功进入到该登录界面则代表系统的开启是成功的,接下来就可以操作本系统所带有的其他所有的功能,如图4-8所示。
图4-8采购员登录界面
采购员登录系统后,可以对系统首页、个人中心、产品信息管理、采购信息管理、供应商管理、公告栏管理等功能进行相应操作,如图4-9所示。
图4-9采购员功能界面图
采购员点击产品信息管理;在产品信息管理页面对产品编号、产品名称、产品类别、品牌、数量 、进货价、销售价、厂家、保质期、备注等信息,进行查询或采购产品等操作;如图4-10所示。
图4-10产品信息管理界面图
4.4销售员功能模块
登录界面,首先双击打开系统,连上网络之后会显示出本系统的登录界面,这是进入系统的第初始页面“登录”,能成功进入到该登录界面则代表系统的开启是成功的,接下来就可以操作本系统所带有的其他所有的功能,如图4-11所示。
图4-11销售员登录界面
销售员登录到系统界面,可以对系统首页、个人中心、产品信息管理、销售订单管理、客户信息管理、公告栏管理等功能进行相应操作,如图4-12所示。
图4-12销售员功能界面图
销售员点击产品信息管理;在产品信息管理页面对产品编号、产品名称、产品类别、品牌、数量 、进货价、销售价、厂家、保质期、备注等信息,进行查询、销售产品等操作;如图4-13所示。
图4-13产品信息管理界面图
销售员点击销售订单管理;在销售订单管理页面对产品编号、产品名称、产品类别、客户名称、品牌、数量 、销售价、总金额、销售工号、销售姓名、销售时间等信息,进行查询或者删除销售数量、销售金额等操作;如图4-14所示。
图4-14销售订单管理界面图
4.5 仓管员管理功能模块
登录界面,首先双击打开系统,连上网络之后会显示出本系统的登录界面,这是进入系统的第初始页面“登录”,能成功进入到该登录界面则代表系统的开启是成功的,接下来就可以操作本系统所带有的其他所有的功能,如图4-15所示。
图4-15仓管员登录界面
仓管员登录到系统界面,可以对系统首页、个人中心、产品类型管理、产品信息管理、商品入库管理、商品出库管理、报损登记管理、公告栏管理等功能进行相应操作,如图4-16所示。
图4-16仓管员功能界面图
仓管员点击商品入库管理;在商品入库管理页面对产品编号、产品名称、产品类别、品牌、入库数量 、仓管工号、仓管姓名、入库时间等信息,进行查询或者删除商品入库等操作;如图4-17所示。
图4-17商品入库管理界面图
5 软件测试
软件测试(Software Testing)是指在设计基本完成后对软件的各项功能进行测试,检测其能否达到在系统设计之初对其的预期情况[11]。预估系统上线后的情况,对出现问题的地方进行及时修改。软件测试作为系统设计的最终阶段,它的准确性往往影响了系统的最终使用感。因为软件是由数据、文档以及程序代码组成的,所以软件测试的对象就不仅仅是程序的本身,还有包括软件设计过程中形成的数据、文档等。但软件测试也存在着问题,软件测试注重的是软件设计的最终结果,其并没有关心整个系统在开发过程中发生的问题。软件测试必须假设和考虑在设计过程中发生的问题。并对软件测试中发现的问题进行回归测试[12]。要更好的通过软件测试检测系统以更好的找出问题来提高系统的质量。软件测试要以最少的人力和经济消耗来完成系统的设计结尾工作。而且所有的测试都要以人为本,任何的测试都要考虑到用户使用的实际体验感,要确保用户有一个好的使用体验。要确保整个软件测试过程都按照原定的规则进行,以确保最终设计的系统的完整性和实用性。
5.1软件测试原则
编筐编篓,重在收口。软件测试的完成效果直接影响到整个系统的使用效果。对于软件测试来说,如果能早点发现系统的漏洞,就能及时修改,可以让设计的成本减少。进行软件测试的时候,测试员们需要制定自己的测试脚本,让这个脚本尽可能多的覆盖系统需要测试的各个路径,避免系统疏漏。同时,在软件测试的过程中,要检测程序有没有进行与系统预期功能要求无关的代码运行。避免多余的程序运行对系统产生破坏,降低效率,增加成本。同时在测试后,还要尽量保留所有测试用例,这样可以帮助日后想要修改时可以及时找到原先的用例,可以再直接进行测试。以下是总结下来比较重要的一些软件测试原则:
(1)要尽可能早的进行软件测试[13]。
随着系统的设计进行,设计过程中每一个阶段发生的错误都有可能导致在后续的开发设计的时候连续出错,如果等到软件设计工作基本全都完成再进行测试,可能会导致大量的错误同时出现,而且很难找到它们出错的源头。因为开发设计的每一步都与后续程序紧密相连,如果不及时找出错误,可能会因一处错误导致后续整个程序瘫痪。所以要坚持尽早进行软件测试的原则,一来可以减少牵一发而动全身的错误,二来可以降低成本。
(2)软件测试证明软件存在缺陷。
通过软件测试可以检测系统设计时是否存在错误和缺陷,但并不能说明系统是不存在任何缺陷的。软件测试的目的是辅助软件开发,让程序员可以尽可能早的发现错误,提高质量。软件开发的过程或多或少都会产生一些错误,软件测试就是尽可能地发现错误和缺陷,尽可能优化程序。
(3)缺陷集群效应原则。
一个软件核心的地方可能就只有那么小的一部分,但就是那一小部分,却能引发软件大规模的损坏。当我们进行软件测试的时候要特别注意那一小部分,也就是核心的部分,因为它们几乎控制了整个软件的稳定性,它们是最容易出现错误的,控制好它们几乎就控制了软件的八成稳定性。但我们也不能只仅限于这小部分模块的检查,也要对剩余的地方进行适当的测试[14]。
(4)以人为本原则。
农机配件仓库管理系统设计的目的就是为人服务,任何的缺陷和错误的修改方向都要在使用者的角度去进行。要做到尽可能贴近使用者的日常模式,从使用者的角度去出发,去修改。
(5)经常更新测试方式。
测试人员应该尽量避免对系统所有的部分都使用同一种测试方式。一些测试方式只能检测特定的模块,并不能对整个系统都进行有效的测试,甚至无法发现一处错误。所以,为了能更好的发挥软件测试的作用,软件测试的时候应该经常更新测试方法,让测试的质量最大化。
5.2测试用例
部分系统测试用例如表5-1所示。
表 5-1 测试用例表
测试功能、流程 预期结果 实际结果 结论
进行登录实验。需要管理员输入相应的信息验证,看能否进入 录入信息验证通过,
转入管理员界面 登陆成功,
成功跳转页面 测试成功
对用户的登录进行测试。管理员就录入特定的信息,看能否成功登录 录入特定信息,
可以登录,可以在数据后台找到信息 可以登录,在后台找到了对应信息 测试成功
测试登录功能是否符合规定。测试员要输入错误的登录信息,检查能否登录 在输入错误的信息后,系统会发现错误,禁止测试人员登录
输入错误信息后,系统禁止登录 测试成功
对兼容性进行测试,让软件在不同的电子类产品上进行登录测试 都可以成功打开软件,正常运行 可以在不同的设备上和其他软件共存 测试成功
续表5-1
测试功能、流程 预期结果 实际结果 结论
安装测试,在试验机上登录软件,检测能否按预期正常运行 登录后可以进行正常操作,可以发行 在试验机上可以正常运行,没有卡顿 测试成功
结 论
农机配件仓库管理系统通过 springboot框架、JAVA语言等技术完成的。系统可以完成用户的基本需求,并且在测试中系统运行情况良好,没有出现异常。但是,还是有许多我需要学习和完善的地方。
农机配件仓库管理系统实现了模块化连接,对应不同的平台可以进行针对性部署,可以进行全方位的覆盖。它实现了跨终端无缝协同体验。但碍于农机配件仓库管理系统刚进入市场发行不久,它的各项数据,功能还没有达到完美的地步。需要进一步的实际运行来完善有缺陷的地方。在这个信息化的时代大家都希望手里的任何一个电子设备都可以完成平时的常见功能,通过农机配件仓库管理系统的开发可以实现这一目标。农机配件仓库管理系统作为国产系统,它的发展前途十分明亮,未来也会拥有很广泛的市场,通过未来的长时间发展,农机配件仓库管理系统的软件开发一定会成为一种趋势,让中国的操作系统发展得到进一步的提升。
参考文献
[1]张荣超.鸿蒙应用开发实战[M].人民邮电出版社.2021(1):34-70.
[2]董昱.HarmonyOS鸿蒙应用程序开发[M].清华大学出版社.2021:30-45.
[3]HarmonyOSIoT设备开发实战[M].人民邮电出版社,2021(1):40-56.
[4]鸿蒙操作系统开发入门经典[M].人民邮电出版社,2021(1)60-75.
[5]武延军.鸿蒙第三方组件库应用开发实战[M].人民邮电出版社,2021(12):40-78.
[6]华为软件技术有限公司.移动应用开发[M].清华大学出版社,2021:15-25.
[7]李亚玲, 韩奥, 鲁建丽, 张航.软件测试初探[J]. 数码世界, 2020: 68-69.
[8]郑明秋, 蒙连超, 赵海侠. MySQL数据库实用教程[M].北京理工大学出版社, 2019: 4.
[9]胡巧儿.MySQL数据库原理与应用项目化教程微课版[M].电子工业出版社.2021:74-79.
[10]周小娟.基于springboot框架与XML技术的工业锅炉智能化监控系统设计[J].工业加热,2020,49(12):31-34.
[11]沈蕴梅. 电子商务网站建设springboot+MySQL项目开发教程[M]. 北京:北京理工大学出版社, 2019:95-102.
[12]向桂玲.XML数据库强制访问控制策略探讨[J].信息与电脑,2022,34(04):186-188.
[13]Vanier Eric, Malepati Tejaswi, Shah Birju. Advanced MySQL 8[M]. Packt Publishing, 2019: 89-95.
[14]Kromann. springboot and MySQL Recipes[M]. Apress, 2020:20-36.
[15]AlDwairi Mahmoud,Shatnawi Ahmed S.,AlKhaleel Osama,AlDuwairi Basheer. Ransomware-Resilient Self-Healing XML Documents[J]. Future Interspringboot,2022,14(4).
致 谢
时光飞逝,转眼间四年的大学就要过去了。当我做到了大学里最后任务的最后一个模块时,我意识到自己将要毕业了,将离开陪伴了自己四年快乐时光的校园。回想起在学校的四年,让我有很深的感触。回想起在学校的点点滴滴,让我有太多无法忘记的人和事。学校的室友,同学,朋友,老师,图书馆,教学楼等,当这些东西在我脑里闪过的时候,我的心里很不是滋味。
首先,我要感谢我的亲人。他们无论何时都是我最亲近的人,无论我对他们怎么发脾气,他们都不会生我的气。每次当我因为某些事而无法承受的时候,他们总是会第一时间来关心我,来给我出主意,帮我度过难关。今后,我也会努力前进,回报我的亲人们对我的支持。
当然,还要感谢我的毕设指导老师。他是一位发自内心希望我们以后能功成名的老师。他陪伴了我几乎整个大学时光,他每次上课的时候都会向我们分享他所做过的程序。将他自己的实战经验授予我们。他会将自己觉的最有用的东西交给我们,还会向我们分享他觉得非常实用的软件,如果我们无法下载,他也会帮我们下载软件。记得在大四上学期的时候,他还帮助我们重装系统,给我们安装最实用的软件。他也是一个非常有责任感的老师,他会经常询问我们的论文情况,如果我们有问题,他都会在第一时间给我们解答。或许对于一位老师来讲,学生学有所成是他的期望。
还要感谢我的室友们。虽然这几年的生活会有磕磕绊绊,但是每次我有困难或者不开心的时候,他们都会给我建议,让我不在难过。每当我过生日的时候,他们都会不约而同的为我庆祝。每当我有困难的时候,他们总是站在我这一边,为我考虑。而在和他们沟通后,我都会从坏心情里走出来,变的愉悦。所以,我也很感谢他们这四年的陪伴。
时光飞逝,四年大学生活转眼间就要过去了。这一刻,四年里的时光又在我的脑海里进行了一遍。我的室友,同学,老师,这一刻,我已止不住自己的泪水。我有太多的回忆永远的刻在了脑子里,我不会忘记他们,不会忘记和他们的点点滴滴。于此同时,我会积极备战考研,吸取第一次的失败经验,争取再二战中取得一个好的成绩,考上心目中理想的学校。我一定会加油的!