Springboot小型仪器公司生产管理系统

摘要

本论文主要论述了如何使用java语言开发一个Springboot小型仪器公司生产管理系统,本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构,面向对象编程思想进行项目开发。在引言中,作者将论述小型仪器公司生产管理系统的当前背景以及系统开发的目的,后续章节将严格按照软件开发流程,对系统进行各个阶段分析设计。

Springboot小型仪器公司生产管理系统的主要使用者分为管理员、和用户,实现功能包括:首页、用户管理(管理员、员工)、更多管理(员工信息管理、产品信息管理、贴片信息管理、组桥信息管理、修四角信息、温补信息、包装信息管理等)由于本网站的功能模块设计比较全面,所以使得整个小型仪器公司生产管理系统的过程得以完善。本系统的使用可以实现小型仪器公司生产管理的信息化,可以方便管理员进行更加方便快捷的管理,可以提小型仪器公司生产管理的管理效率。

关键词:MYSQL数据库;小型仪器公司生产管理;Springboot框架

Production management system of springboot small instrument company

Abstract

This paper mainly discusses how to use java language to develop a production management system of springboot small instrument company. This system will carry out the work of each stage in strict accordance with the software development process, and adopt B / S architecture and object-oriented programming idea for project development. In the introduction, the author will discuss the current background of the production management system of small instrument company and the purpose of system development. The subsequent chapters will analyze and design the system in each stage in strict accordance with the software development process.

The main users of the production management system of springboot small instrument company are divided into administrators, and users. The functions include: home page, user management (administrators and employees), more management (employee information management, product information management, patch information management, bridge information management, corner repair information, temperature supplement information, packaging information management, etc.). Due to the comprehensive design of the functional modules of this website, Therefore, the process of the production management system of the whole small instrument company can be improved. The use of this system can realize the informatization of warehouse management, facilitate the administrator to manage more conveniently and quickly, and improve the management efficiency of production management of small instrument companies.

Key words :Mysql database; Production management of small instrument company; Springboot framework

目 录

摘要

1 绪论

1.1研究背景

1.2研究现状

1.3研究内容

2 相关技术介绍

2.1J2EE技术 8

2.2 MVVM模式 8

2.3 B/S结构 9

2.4 MVVM模式介绍 9

2.5 Spring boot框架 10

2.6 Mysql数据库 11

2.7 B/S体系工作原理

3 系统分析

3.1 可行性分析

3.1.1 技术可行性

3.12经济可行性

3.1.3操作可行性

3.2 系统性能分析

3.3 系统功能分析

3.4系统流程分析

3.4.1登录流程

3.4.2注册流程

3.4.3添加信息流程

3.4.4删除信息流程

4 系统设计

4.1系统概要设计

4.2系统结构设计

4.3系统顺序图设计

4.3.1登录模块顺序图

4.3.2添加信息模块顺序图

4.4数据库设计

4.4.1数据库E-R图设计

4.4.2数据库表设计

5 系统详细设计

5.1系统功能模块

6 系统测试

6.1 测试定义

6.2 测试目的

6.3测试方案

(1)模块测试

(2)集成测试:

(3)验收测试:

6.4系统分析

7 结论

参考文献

谢辞

1 绪论

1.1研究背景

随着计算机技术、信息技术的发展和应用,促进了制造业企业生产力的提高,从单纯的设计与开发到了现在的集产品设计、制造、生产管理、进销存管理于一体的计算机集成生产管理系统。中小型制造型企业由于自身资金有限,产品变化快的特点,根据企业的实际需求,开发一个适应其企业的生产管理系统。并且该系统能够满足企业的各项功能需求,帮助企业解决了生产管理中存在的一些实际问题,加强了企业的生产管理水平,极大地提高生产效率。使用生产管理系统可以加快企业各个生产部门、管理部门之间的信息交流,实现的了管理科学化、规范化、高效化,进一步降低生产成本,提高企业经济效率。

我国中小企业占企业总数的90% ,在我国的经济建设中是一支非常重要的力量。随着计算机网络技术的快速发展,我国中小企业面临着各种各样的挑战,主要是资金短缺、管理流程不明确,企业信息化程度不高、绝大多数员工文化素质不高。目前国内中小型制造企业的信息化水平还是较低,由于中小企业的灵活多变、产品多样化的特点,完成照搬大型企业的生产管理模式不能满足中小型企业的实际需求,这就需要设计能够满足中小型制造企业的生产信息管理系统。基于对中小型制造企业的实际情况的考虑,开发了基于B/S模式的小型仪器公司生产信息管理系统,该系统最大限度地方便了用户操作和系统维护,从而大大地降低的企业的生产成本,提高了企业的生产效率。

1.2研究现状

国内大多数中小型企业生产管理信息化水平较低,不能满足高效、准确、及时工作的需求,制约着企业的进一步拓展和产品品质的持续提升,从而影响到整个业务的顺利进行。随着市场竞争的加剧,管理技术和信息技术的发展,企业实施信息化改造成为提高企业竞争力的必然途径。论文针对小型仪器生产公司存在的生产计划、产品订单、原料采购、销售情况、供应商情况、产品库存掌握不及时等问题,开发了一套生产信息管理系统。通过分析公司在运营过程中存在的问题和业务需求,确定了开发信息管理系统的设计目标需求、功能需求和非功能需求,建立了系统的用例模型。根据系统需求对开发模式、开发环境、开发工具进行了选择,对系统进行了体系结构设计和功能模块划分,并以MySQL5.5为数据库管理系统,在其基础上阐述了表、域和布局的设计。随后详细讨论了用户界面的设计,给出了产品信息管理、订单管理、产品库存管理、产品销售和供应商管理模块的详细设计与实现。最后,论文分析了系统的测试流程和运行结果。系统采用交互式系统设计的三层体系结构,以MySQL5.5为数据库,基于分离设计原则,实现公司各类信息数据的录入、编辑、查找、修改和删除等操作,并为公司业务的发展提供了扩展接口。本系统功能实用、界面友好、操作编辑,具有良好的体系机构和可扩展性,系统坛行稳定,安全可靠,满足了公司的业各需求。

1.3研究内容

该小型仪器公司生产管理系统的开发和设计根据用户的实际情况出发,对系统的需求进行了详细的分析,然后进行系统的整体设计,最后通过测试使得系统设计的更加完整,可以实现系统中所有的功能,在开始编写论文之前亲自到图书馆借阅Springboot框架书籍,MYSQL数据库书籍等编程书籍,然后针对开发的小型仪器公司生产管理平台系统,去网上查找了很多别人做好的系统,参照他们的设计结果,来对自己的系统进行更加详细的系统的设计,将系统中所有的功能结果一一列举出来,然后进行需求分析,最后对所有的功能模块进行编码,最后完成系统的整体测试,实现系统的正常运行。

这次编写的论文包含了6个部分的内容,具体内容如下:

第一部分绪论:文章主要从课题背景以及研究现状综合阐述了开发此系统的必要性。

第二部分相关技术:系统开发用到的各种技术都大致做出了简介。

第三部分系统分析:对系统的可行性分析以及对所有功能需求进行详细的分析,来查看该系统是否具有开发的可能。

第四部分系统设计:功能模块设计和数据库设计这两部分内容都有专门的表格和图片表示。

第五部分系统实现:进行系统主要功能模块的界面展示。

第六部分系统测试:测试系统的每一个功能是否能够正常运行,是否可以满足人们的需求。

2 相关技术介绍

2.1J2EE技术

人可以掌握多门外语,而一个计算机科学家精通的大多是编程语言,它不是人类的自然语言,比如C语言、Java、Perl等等。由于不同的公司开发出的“中间件”不够规范,所以Sun公司推出J2EE,用这个标准来解决弊病。它提供了良好的机制,让每个层次允许与之相对的服务器、组件运行,使得系统的搭建稳定可用、开发高效、维护方便。

2.2 MVVM模式

MVVM模式是常用的开发模式,主要是在代码实现上将其分为M层、V层和C层。

视图(View)代表用户交互界面,一个 Web 应用就可能有很多的界面,在 MVVM 模式中,视图仅仅处理的只有数据采集、处理,还有用户的请求, 并不包括业务流程的处理,业务流程由模型(Model)来处理。

模型(Model)就是业务流程/状态的处理及业务规则的制定。模型处理业务流程的过程其它层是无法看见了的,它就像黑箱子,在接受视图请求的数据之后,然后返回最终的处理结果。MVVM 最主要的核心就是业务模型的设计,一个典型的应用例子就是目前流行的 EJB 模型,它从应用技术实现的角度对模型做了进一步的划分,以便充分利用现有的组件,但是它不能作为应用设计模型的框架。

控制器(Controller)可以理解为接收用户的请求,然后视图和模型匹配在一起,一起再完成用户请求。它有非常明显的作用在划分控制层上,可以很清晰地告诉你,它就是一个分发器,选择什么样的模型、视图,可以完成用户的什么样的请求。控制层不做所有的数据处理,比如说:用户点击一个连接,控制层接受到请求之后,并不处理业务信息,它只是向模型传递用户的信息,同时告诉模型做什么,然后选择符合需求的视图返回给用户。

2.3 B/S结构

B/S(Browser/Server)比前身架构更为省事的架构。它借助Web server完成数据的传递交流。只需要下载浏览器作为客户端,那么工作就达到“瘦身”效果, 不需要考虑不停装软件的问题。

2.4 Spring boot框架

Spring框架是Java平台上的一种开源应用框架,提供具有控制反转特性的容器。尽管Spring框架自身对编程模型没有限制,但其在Java应用中的频繁使用让它备受青睐,以至于后来让它作为EJB(EnterpriseJavaBeans)模型的补充,甚至是替补。Spring框架为开发提供了一系列的解决方案,比如利用控制反转的核心特性,并通过依赖注入实现控制反转来实现管理对象生命周期容器化,利用面向切面编程进行声明式的事务管理,整合多种持久化技术管理数据访问,提供大量优秀的Web框架方便开发等等。Spring框架具有控制反转(IOC)特性,IOC旨在方便项目维护和测试,它提供了一种通过Java的反射机制对Java对象进行统一的配置和管理的方法。Spring框架利用容器管理对象的生命周期,容器可以通过扫描XML文件或类上特定Java注解来配置对象,开发者可以通过依赖查找或依赖注入来获得对象。Spring框架具有面向切面编程(AOP)框架,SpringAOP框架基于代理模式,同时运行时可配置;AOP框架主要针对模块之间的交叉关注点进行模块化。Spring框架的AOP框架仅提供基本的AOP特性,虽无法与AspectJ框架相比,但通过与AspectJ的集成,也可以满足基本需求。Spring框架下的事务管理、远程访问等功能均可以通过使用SpringAOP技术实现。Spring的事务管理框架为Java平台带来了一种抽象机制,使本地和全局事务以及嵌套事务能够与保存点一起工作,并且几乎可以在Java平台的任何环境中工作。Spring集成多种事务模板,系统可以通过事务模板、XML或Java注解进行事务配置,并且事务框架集成了消息传递和缓存等功能。Spring的数据访问框架解决了开发人员在应用程序中使用数据库时遇到的常见困难。它不仅对Java:JDBC、iBATS/MyBATIs、Hibernate、Java数据对象(JDO)、ApacheOJB和ApacheCayne等所有流行的数据访问框架中提供支持,同时还可以与Spring的事务管理一起使用,为数据访问提供了灵活的抽象。Spring框架最初是没有打算构建一个自己的WebMVC框架,其开发人员在开发过程中认为现有的StrutsWeb框架的呈现层和请求处理层之间以及请求处理层和模型之间的分离不够,于是创建了SpringMVC。

2.5 MySQL数据库

Mysql的语言是非结构化的,用户可以在数据上进行工作。MySQL因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下,MySQL是管理内容最好的选择。并且因为Mysql的语言和结构比较简单,但是功能和存储信息量很强大,所以得到了普遍的应用。

Mysql数据库在编程过程中的作用是很广泛的,为用户进行数据查询带来了方便。Mysql数据库的应用因其灵活性强,功能强大,所以在实现某功能时只需要一小段代码,而不像其他程序需要编写大段代码。总体来说,Mysql数据库的语言相对要简洁很多。

数据流程分析主要就是数据存储的储藏室,它是在计算机上进行的,而不是现实中的储藏室。数据的存放是按固定格式,而不是无序的,其定义就是:长期有固定格式,可以共享的存储在计算机存储器上。数据库管理主要是数据存储、修改和增加以及数据表的建立。为了保证系统数据的正常运行,一些有能力的处理者可以进行管理而不需要专业的人来处理。数据表的建立,可以对数据表中的数据进行调整,数据的重新组合及重新构造,保证数据的安全性。介于数据库的功能强大等特点,本系统的开发主要应用了Mysql进行对数据的管理。

2.6 B/S体系工作原理

B/S架构采取浏览器请求,服务器响应的工作模式。

用户可以通过浏览器去访问Internet上由Web服务器产生的文本、数据、图片、动画、视频点播和声音等信息;

而每一个Web服务器又可以通过各种方式与数据库服务器连接,大量的数据实际存放在数据库服务器中;

从Web服务器上下载程序到本地来执行,在下载过程中若遇到与数据库有关的指令,由Web服务器交给数据库服务器来解释执行,并返回给Web服务器,Web服务器又返回给用户。在这种结构中,将许许多多的网连接到一块,形成一个巨大的网,即全球网。而各个企业可以在此结构的基础上建立自己的Internet。

在 B/S 模式中,用户是通过浏览器针对许多分布于网络上的服务器进行请求访问的,浏览器的请求通过服务器进行处理,并将处理结果以及相应的信息返回给浏览器,其他的数据加工、请求全部都是由Web Server完成的。通过该框架结构以及植入于操作系统内部的浏览器,该结构已经成为了当今软件应用的主流结构模式。

3 系统分析

3.1 可行性分析

在系统开发之初要进行系统可行分析,这样做的目的就是使用最小成本解决最大问题,一旦程序开发满足用户需要,带来的好处也是很多的。下面我们将从技术上、操作上、经济上等方面来考虑这个系统到底值不值得开发。

3.1.1 技术可行性

本智能管理系统采用Springboot框架技术、java语言和MYSQL数据库进行开发设计,作为计算机专业学生,在学校期间就接触到许多关于编程方面的知识,当然也包括各种编程软件,对他们的了解度也比较系统,所以技术开发上面还是有一定把握。

3.1.2经济可行性

我在设计该系统的时候主要是从节约成本出发,然后进行具体的系统的设计,在系统的设计过程中由于采用的所有工具以及技术支持全部都是免费的,因此不需要有任何的成本就可以进行该系统的设计。所用到的所有资源都是免费的,只要有网络就可以进行下载使用,不需要支付相应的费用,因此该项目在经济方面是完全可以实行的。

3.1.3操作可行性

本人自己就是学生,程序开发经验不足,在界面设计上面不会设计太复杂,要讲究简单好看,操作上要方便,不能让用户觉得不流畅。用户一旦进入操作界面,界面上就会有相应提示,跟着操作提示就可以找到对应的功能操作模块,对于用户来说免培训就能使用。

从上面几个部分的可行性分析得出,这次开发的小型仪器公司生产管理系统在开发上面没有什么大问题,值得开发。

3.2 系统性能分析

(1)系统响应效率:页面响应时问应该在3秒以内,最长不能超过4秒,并支持至少10000人同时在线所有系统。

(2)界面简洁清晰:系统界面要求简单明了,容易操作,符合用户操作习惯。

(3)储存性高:因为小型仪器公司生产管理系统中有很多的信息需要存储,因此对于系统的存储量有很大的要求,需要有一个强大的数据库的支持才能确保所有的信息都能安全稳定的进行存储。

(4)易学性:该系统在操作上必须简单好上手,没有很多复杂的操作,只需要简单的进行学习就能操作该系统。

(5)稳定性需求:开发的小型仪器公司生产管理系统要求运行稳定,运行过程中无界面不清楚、字体模糊等现象。

(6)稳定性:开发的小型仪器公司生产管理系统要求运行稳定,运行过程中无界面不清楚、字体模糊等现象。

3.3 系统功能分析

本小型仪器公司生产管理系统主要包括两大功能模块,即管理员功能模块和员工模块。

(1)管理员模块:系统中的核心用户是系统管理员,管理员登录后,通过管理员菜单来管理后台系统。主要功能有:首页、用户管理(管理员、员工)、更多管理(员工信息管理、产品信息管理、贴片信息管理、组桥信息管理、修四角信息、温补信息、包装信息管理)等功能。管理员用例图如图3-1所示。

图3-1 管理员用例图

(2)员工:包括组桥信息、产品信息、贴片信息、修四角信息、包装信息等。员工用例图如图3-2所示。

图3-2 员工用例图

3.4系统流程分析

3.4.1登录流程

登录模块主要满足管理员、员工的权限登录,登录流程图如图3-3所示。

图3-3 登录流程图

3.4.2注册流程

未有账号的用户可进入注册界面进行注册操作,用户注册流程图如图3-4所示。

图3-4 注册流程图

3.4.3添加信息流程

用户在添加信息时,信息编号自动生成,系统会对添加的信息进行验证,验证通过则添加至数据库,添加信息成功,反之添加失败。添加信息流程如图3-5所示。

图3-5 添加信息流程图

3.4.4删除信息流程

用户可选择要删除的信息进行信息删除操作,在删除信息时系统提示是否确定删除信息,是则删除信息成功,系统数据库将信息进行删除。删除信息流程图如图3-6所示。

图3-6 删除信息流程图

4 系统设计

4.1系统概要设计

本小型仪器公司生产管理系统选择B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式。适合在互联网上进行操作,只要用户能连网,任何时间、任何地点都可以进行系统的操作使用。系统工作原理图如图4-1所示:

图4-1 系统工作原理图

4.2系统结构设计

整个系统是由多个功能模块组合而成的,要将所有的功能模块都一一列举出来,然后进行逐个的功能设计,使得每一个模块都有相对应的功能设计,然后进行系统整体的设计。

本小型仪器公司生产管理系统结构图如图4-2所示。

图4-2 系统功能结构图

4.3系统顺序图设计

4.3.1登录模块顺序图

登录模块主要满足了管理员、员工的权限登录,登录模块顺序图如图4-3所示。

图4-3 登录顺序图

4.3.2添加信息模块顺序图

管理员、员工登录后均可进行添加信息操作,添加信息模块顺序图如图4-4所示。

图4-4 添加信息顺序图

4.4数据库设计

一个好的数据库可以关系到程序开发的优劣,数据库设计离不开表结构的设计,还有表与表之间的联系,以及系统开发需要设计的数据表内容等信息。在进行数据库设计期间,要结合实际情况来对数据库进行针对性的开发设计。

4.4.1数据库E-R图设计

本小型仪器公司生产管理系统采用的是MYSQL数据库,数据存储快,因为小型仪器公司生产管理系统,主要的就是对信息的管理,信息内容比较多,这就需要好好的设计一个好的数据库,分类要清楚,不能添加信息的时候,造成信息太过混乱,设计好的数据库首先就需要先把各个实体之间的关系表达明确。

系统的E-R图如下图所示:

图4-5 系统E-R图

4.4.2数据库表设计

将数据库概念设计的E-R图转换为关系数据库。在关系数据库中,数据关系由数据表组成,但是表的结构表现在表的字段上。

名称

类型

长度

不是null

主键

注释

employee_information_id

int

11

员工信息ID

process_name

varchar

64

工序名称

employee_name

varchar

64

员工姓名

employee_gender

varchar

64

员工性别

employee_telephone

varchar

64

员工电话

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

apply_terminal_glue_id

int

11

涂端子胶ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

production_date

date

0

投产日期

production_quantity

varchar

64

投产数量

procedure_8_employee_name

varchar

64

工序8员工姓名

process_7_waste

varchar

64

工序8废料

completion_time

time

0

完成时间

complete

varchar

64

是否完成

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

bridge_information_id

int

11

组桥信息ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

production_date

date

0

投产日期

production_quantity

varchar

64

投产数量

procedure_3_employee_name

varchar

64

工序3员工姓名

process_3_waste

varchar

64

工序3废料

completion_time

time

0

完成时间

complete

varchar

64

是否完成

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

four_corner_information_id

int

11

修四角信息ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

production_date

date

0

投产日期

production_quantity

varchar

64

投产数量

procedure_6_employee_name

varchar

64

工序6员工姓名

process_6_waste

varchar

64

工序6废料

completion_time

time

0

完成时间

complete

varchar

64

是否完成

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

online_information_id

int

11

上线信息ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

production_date

date

0

投产日期

production_quantity

varchar

64

投产数量

procedure_5_employee_name

varchar

64

工序5员工姓名

process_5_waste

varchar

64

工序5废料

completion_time

time

0

完成时间

complete

varchar

64

是否完成

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

packaging_information_id

int

11

包装信息ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

production_date

date

0

投产日期

production_quantity

varchar

64

投产数量

procedure_9_employee_name

varchar

64

工序9员工姓名

process_7_waste

varchar

64

工序9废料

completion_time

time

0

完成时间

complete

varchar

64

是否完成

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

patch_information_id

int

11

贴片信息ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

production_date

date

0

投产日期

production_quantity

varchar

64

投产数量

procedure_2_employee_name

varchar

64

工序2员工姓名

process_2_waste

varchar

64

工序2废料

completion_time

time

0

完成时间

complete

varchar

64

是否完成

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

scribing_and_lettering_id

int

11

划线刻字ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

production_date

date

0

投产日期

production_quantity

varchar

64

投产数量

procedure_1_employee_name

varchar

64

工序1员工姓名

completion_time

time

0

完成时间

waste_mark

varchar

64

工序1废料

complete

varchar

64

是否完成

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

shipping_information_id

int

11

发货信息ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

the_date_of_issuance

date

0

发货日期

shipment_quantity

varchar

64

发货数量

shipping_address_

varchar

64

发货地址

consignee_name_

varchar

64

收货人姓名

receiving_telephone

varchar

16

收货电话

receiving_address

varchar

64

收货地址

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

waste_management_id

int

11

废料管理ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

production_date

date

0

投产日期

receipt_quantity

varchar

64

入库数量

total_waste

varchar

64

废料数量

scrap_number

varchar

64

废料编号

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

名称

类型

长度

不是null

主键

注释

temperature_compensation_information_id

int

11

温补信息ID

serial_number

varchar

64

序号

product_number

varchar

64

产品编号

product_model

varchar

64

产品型号

production_date

date

0

投产日期

production_quantity

varchar

64

投产数量

procedure_7_employee_name

varchar

64

工序7员工姓名

process_7_waste

varchar

64

工序7废料

completion_time

time

0

完成时间

complete

varchar

64

是否完成

recommend

int

11

智能推荐

create_time

datetime

0

创建时间

update_time

timestamp

0

更新时间

5 系统详细设计

5.1系统功能模块

小型仪器公司生产管理系统,在系统登录页面管理员填写账号、密码等信息进行登录,如图5-1所示。

图5-1管理员登录界面图

管理员登录的关键代码如下。

/**

* 登录

* @param data

* @param httpServletRequest

* @return

*/

@PostMapping("login")

public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {

log.info("[执行登录接口]");

String username = data.get("username");

String email = data.get("email");

String phone = data.get("phone");

String password = data.get("password");

List resultList = null;

Map<String, String> map = new HashMap<>();

if(username != null && "".equals(username) == false){

map.put("username", username);

resultList = service.select(map, new HashMap<>()).getResultList();

}

else if(email != null && "".equals(email) == false){

map.put("email", email);

resultList = service.select(map, new HashMap<>()).getResultList();

}

else if(phone != null && "".equals(phone) == false){

map.put("phone", phone);

resultList = service.select(map, new HashMap<>()).getResultList();

}else{

return error(30000, "账号或密码不能为空");

}

if (resultList == null || password == null) {

return error(30000, "账号或密码不能为空");

}

//判断是否有这个用户

if (resultList.size()<=0){

return error(30000,"用户不存在");

}

User byUsername = (User) resultList.get(0);

Map<String, String> groupMap = new HashMap<>();

groupMap.put("name",byUsername.getUserGroup());

List groupList = userGroupService.select(groupMap, new HashMap<>()).getResultList();

if (groupList.size()<1){

return error(30000,"用户组不存在");

}

UserGroup userGroup = (UserGroup) groupList.get(0);

//查询用户审核状态

if (!StringUtils.isEmpty(userGroup.getSourceTable())){

String sql = "select examine_state from "+ userGroup.getSourceTable() +" WHERE user_id = " + byUsername.getUserId();

String res = String.valueOf(service.runCountSql(sql).getSingleResult());

if (res==null){

return error(30000,"用户不存在");

}

if (!res.equals("已通过")){

return error(30000,"该用户审核未通过");

}

}

//查询用户状态

if (byUsername.getState()!=1){

return error(30000,"用户非可用状态,不能登录");

}

String md5password = service.encryption(password);

if (byUsername.getPassword().equals(md5password)) {

// 存储Token到数据库

AccessToken accessToken = new AccessToken();

accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));

accessToken.setUser_id(byUsername.getUserId());

tokenService.save(accessToken);

// 返回用户信息

JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));

user.put("token", accessToken.getToken());

JSONObject ret = new JSONObject();

ret.put("obj",user);

return success(ret);

} else {

return error(30000, "账号或密码不正确");

}

}

员工管理页面,管理员可对员工信息进行添加、修改或删除,添加员工账号、姓名、工序名称、员工性别、员工电话等信息,如图5-2所示。

图5-2 员工管理界面图

员工管理的逻辑代码如下:

@PostMapping("/add")

@Transactional

public Map<String, Object> add(HttpServletRequest request) throws IOException {

service.insert(service.readBody(request.getReader()));

return success(1);

}

@Transactional

public Map<String, Object> addMap(Map<String,Object> map){

service.insert(map);

return success(1);

}

public Map<String,Object> readBody(BufferedReader reader){

BufferedReader br = null;

StringBuilder sb = new StringBuilder("");

try{

br = reader;

String str;

while ((str = br.readLine()) != null){

sb.append(str);

}

br.close();

String json = sb.toString();

return JSONObject.parseObject(json, Map.class);

}catch (IOException e){

e.printStackTrace();

}finally{

if (null != br){

try{

br.close();

}catch (IOException e){

e.printStackTrace();

}

}

}

return null;

}

public void insert(Map<String,Object> body){

StringBuffer sql = new StringBuffer("INSERT INTO ");

sql.append("`").append(table).append("`").append(" (");

for (Map.Entry<String,Object> entry:body.entrySet()){

sql.append("`"+humpToLine(entry.getKey())+"`").append(",");

}

sql.deleteCharAt(sql.length()-1);

sql.append(") VALUES (");

for (Map.Entry<String,Object> entry:body.entrySet()){

Object value = entry.getValue();

if (value instanceof String){

sql.append("'").append(entry.getValue()).append("'").append(",");

}else {

sql.append(entry.getValue()).append(",");

}

}

sql.deleteCharAt(sql.length() - 1);

sql.append(")");

log.info("[{}] - 插入操作:{}",table,sql);

Query query = runCountSql(sql.toString());

query.executeUpdate();

}

废料管理页面,在废料管理页面,可删除或添加废料信息,如图5-3所示。

图5-3 废料管理面图

产品信息管理页面,在产品信息添加页面先填写产品编号、产品名称、产品型号、投产日期、投产数量等信息完成产品信息录入,如图5-4所示

图5-4产品信息管理界面图

产品信息管理界面逻辑代码如下:

@RequestMapping(value = {"/avg_group", "/avg"})

public Map<String, Object> avg(HttpServletRequest request) {

Query count = service.avg(service.readQuery(request), service.readConfig(request));

return success(count.getResultList());

}

入库信息管理页面,管理员登录系统,在入库信息页面输入产品编号、产品型号、投产日期、入库数量、入库日期等信息如图5-5所示。

图5-5入库信息管理界面图

入库信息管理界面逻辑代码如下:

@RestController

@RequestMapping("auth")

public class AuthController extends BaseController<Auth, AuthService> {

/**

* 服务对象

*/

@Autowired

public AuthController(AuthService service) {

setService(service);

}

}

包装信息管理页面,管理员登录系统,在包装信息页面输入产品编号、产品型号、投产日期、投产数量、工序废料、完成时间等信息,并进行维护管理如图5-6所示

图5-6包装信息管理界面图

包装信息管理界面关键代码如下:

@RequestMapping("/get_list")

public Map<String, Object> getList(HttpServletRequest request) {

Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));

return success(map);

6 系统测试

一个系统设计好后,就会进入测试阶段,测试的目标是检验设计好的网站是否可以正常无误的运行,尽可能的发现网站的问题,已使后期网站投入使用后网站尽少出错[12]。

6.1 测试定义

系统测试主要是判断系统是否可以正常运行,功能模块是否可以实现操作。程序代码中是否有错误出现。测试程序是开发过程中的一个主要问题。就算系统完成的再好,再进行程序测试时也会也会发现一个重来没有被发现的错误信息。

测试不仅是系统开发的开始,而且应该贯穿整个系统的整个生命周期。评估系统质量的方法不局限于系统编码和过程,应该与软件设计工作和历史需求分析密切相关。系统错误,不一定是代码错误,可能是阶段的设计摘要和设计细节存在问题,问题也可能出现在需求分析阶段。从实际情况来看,最初的问题很可能是一个小错误,根据按钮的原理,按钮后的按钮位错将是所有位错。该系统的原因也同样适用,随着后续的开发工作,误差将越来越严重。因此就应该对系统进行测试,在一开始就发现系统中存在的问题,就能保证以后系统能够正常稳定的运行。在测试系统中,开发人员应该站在客户的角度来处理测试工作,而现在主要的测试方法是黑盒测试。测试的目的可以概括为以下几点:首先,用户界面和客户需求是一致的,设置界面和设计风格统一;第二,创新设计接口规范设计标准,具有独特的审美特征;最后,人类传统的接口以满足审美需求,不能盲目地追求一种独特的,合理的规划布局,符合审美标准。

6.2 测试目的

测试的目的在于要对系统的稳定和可操作性能进行对照检查。对于软件的开发利用最终的目的在最后的测试和试用,这是一个不可缺少的重要环节。对于软件开发者而言,在对每一个单独的功能进行编排时候,都要有单独的测试,并通过测试阶段才可以研发多个功能性软件,这样既缩短了研发时间,也可以在的单个的早期测试中发现问题,以免融合后的软件,在查找问题时就很难快速解决或者急速定位问题。

Springboot小型仪器公司生产管理系统开发设计完成后,需要对其进行系统测试,测试的主要目的就是发现并找出系统中存在的问题,并及时的进行解决,确保系统可以正常稳定的运行下去,在进行系统测试的时候,在一定要非常的认真、仔细,切记不能粗心,不能放过一个漏洞,测试时候一定不要着急,要按照之前指定好的测试步骤一步一步进行,并且将测试的结果进行详细的记录,我们在进行测试的时候做好选择自动化的测试,这样既可以节省时间而且也能确保测试的准确性,如果采用人工测试的方法就不会这么的方便,由于人工测试有很多不确定的因素,在测试过程中很可能会出现一些问题,用机器测试就不会出现任何的问题,而且机器不会疲惫会一直二等工作下去。在测试的时候一定要非常专注,时刻关注着测试的结果,一但发现异常及时进行修改,最后,测试完之后的文档应该保存下来,方便以后测试时用到。系统测试的方法有很多,对于本智能小型仪器公司生产管理平台系统的测试,我们使用了测试用得最多的黑盒测试方法来对该系统进行测试。

6.3测试方案

对测试计划的把握是测试方案的重中之重。所有的技术难点应该都被包含在这个测试计划之中。而且我们要保证能与目标形成一致性,以至于能够测试出一些主要存在的错误和一些错误的漏洞。可以完美解决这些问题就只有白盒测试或者黑盒测试。

构造测试是白盒测试的另一个名字,了解与分析程序的结构以及性能功用的,从而我们可以得到最终想要的结果并且观察出是不是每一条程序都能得到。

性能测试是黑盒测试别称,程序本身的运作通过程序的进程来观察,主要是看一下程序是不是能够像我们预期的目标那样发展,看一看我们的程序最终能不能完整的得到我们最后想要的功能和储存想得到的数据,到最后看一下我们的这个程序完整性能不能达到要求。

(1)模块测试

单元测试就是模块测试,顾名思义就是测试每个模块所承担的功能是否能够实现,这个测试就是为了找出代码在实际的设计运转中某一些小的程序所出现的偏差,很好地改正这些错误,就说明我们模块测试进行很成功过。

(2)集成测试:

集成测试就是对系统的测试以及对他子系统的一些性能测试,他检查的事系统的包装程序信息。找出其中的问题。他的优势主要有以下这几点:

软件耗费较少。

可以提前发现端口的错误。

更好的地位系统中错误的位置。

从底部往上面进行的方案针对于偏下层的结构,而中间的结构就采用折中的方法。

(3)验收测试:

终于到了结尾性的工作了。就是为了给用户看一下我们的系统功能是否达到了预期的效果。我采用了性能测试也就是黑盒测试对系统进行测试。

其结果是分别是:

有一定的差异在用户的需求。

再者就是结果与之差不了多少。

到了最后了,我们发现的问题都是与用户的需求存在一定的关联。

1、登录测试

测试点:登录

测试的目标:输入账号密码以及验证码后系统会自动进行验证是否正确。

所用的环境:Windows10和IE浏览器。

输入信息:用户名、密码。

步骤:

(1)首先我们打来浏览器,进入该系统的登录界面。

(2)在进入页面登录部分以后可以进行对用户名、密码进行测试,具体测试输入情况如下表6.1所示。

表6.1 登录测试

情况

用户名输入

密码输入

期望结果

(1)

15546219225

1244566

提示“用户名或者密码错误,或账号未经审核”

(2)

aaaaa

123456

提示“用户名或密码错误,或者账号未经审核”

(3)

15546219225

hangguowei

登陆成功

6.4系统分析

本小型仪器公司生产管理系统设计要求基本都可以达到,此系统具有完整的软件功能,良好的用户界面,能够正确的处理错误信息,而且能够准确的提出错误的种类。但是系统测试时也出现了一些系统的不足和缺陷,所以在今后的日子里我会对其视觉上的不足作出修改,其次系统的代码和数据库出现了非常多的冗余现象,都是因为对编程技术的应用不够熟练,在日后我会加强自己的自身学习和能力,减少这样的冗余现象。

经过对上述的测试结果分析,本小型仪器公司生产管理系统无论是在技术方面,还是操作方面,还是经济方面都是完全可以实行的,并且经过测试,该系统操作简单,所有的功能都可以实现,因此该系统可以满足人们的使用需求,值得被推广。

总体说来,软件通过测试。

7 结论

本文研究了Springboot小型仪器公司生产管理系统的设计与实现,在文章开端首先对个研究背景、研究现状和研究内容作了简单的介绍,然后通过系统分析,引申出本系统研究的主要内容。

通过对Springboot框架技术和MYSQL数据库的简介,从硬件和软件两反面说明了智能小型仪器公司生产管理平台系统的设计与实现的可行性,本文结论及研究成果如下:实现了Springboot框架与mysql数据库相结合构建的小型仪器公司生产管理系统,通过本次小型仪器公司生产管理系统的设计与实现的研究与实现,我感触到学习一门新技术,最重要的是实践,只有多动手才能尽快掌握它,一个系统的开发,经验是最重要的,经验不足,就难免会有许多考虑不周之处。要想吸引更多的用户,系统的界面必须要美观、有特色、友好,功能要健全。

由于在此之前对于Springboot知识并不了解,所以从一开始就碰到许多困难,例如一开始的页面显示不规范、数据库连接有问题已经无法实现参数的传递等等,不过通过我不断的查阅相关的资料,以及向老师同学请教,最后出现的所有的问题都得到了解决,通过这次的系统开发,我学到了很多的知识,也明白了自己在哪些方面有不足的地方,尤其是学会如何从大量的信息中筛选出所需有用的信息,同时我更加深刻的体会到了,虽然书本上的大部分知识都是有价值,正确的,但实际上每个人编程的思路和对数据处理的方法、思想都是不同的,这就要求我们一定要通过实践才能找到解决问题的方案。在此次毕业设计活动中,我不断的提高了自己,也得到了宝贵的经验,我相信这些对我以后的发展都会有很大帮助。

通过这次小型仪器公司生产管理系统的开发,让我学到了更多的知识,同时通过这次系统的设计也让我明白了自己在哪方面有不足,以后加以学习争取可以开发住更多有用的适用的系统软件,本次系统的设计提高了我的编程水平,为了我今后系统的开发打下了结实的基础。

参考文献

[1]陈晓婧.中小型饲料企业生产管理调度对企业绩效的影响[J].中国饲料,2021(24):91-94.

[2]宋旭. 基于MES系统的NC公司生产管理改进措施研究[D].江西财经大学,2021.

[3]王元. SR公司电子产品生产车间精益生产管理应用研究[D].西北大学,2021.

[4]牛栗果. 基于精益生产的B公司装配线生产管理优化研究[D].华北电力大学,2021.

[5]高学芹.基于物联网的制造企业生产管理系统设计[J].信息技术,2021(06):46-50+57.

[6]张勇. 基于精益管理思想的A公司绕线生产线生产管理改善研究[D].南昌大学,2021.

[7]张玉文. 面向生产管理系统的知识共享平台的设计与实现[D].电子科技大学,2021.

[8]王奕怡. 基于云平台的生产管理系统设计及关键技术研究[D].杭州电子科技大学,2021.

[9]熊思桥,曲冠晨,薛翻琴,赵占一.“多测合一”数据综合生产管理系统建设[J].北京测绘,2020,34(12):1694-1698.

[10]薛中伟. 青岛KEY食品公司安全生产管理研究[D].哈尔滨工程大学,2020.

[11]于泓聿. 基于MES的F汽车零部件公司生产管理改进研究[D].吉林大学,2020.

[12]周烨. 电力公司生产管理系统的设计与实现[D].电子科技大学,2020.

[13]李秀杰. J公司生产管理架构改善研究[D].山东大学,2019.

[14]李亚会. 基于精益生产理论的B服装公司生产管理优化设计与研究[D].北京交通大学,2019.

[15]杨成玮. A公司智能制造生产管理体系构建研究[D].吉林大学,2019.

致谢

本次毕业设计圆满的结束了,通过这次毕业设计我学到了很多的知识,也提高了我软件开发的能力,在系统开发设计的过程中,出现了很多的问题,但是通过老师和同学们的帮助,最后所有的问题都得到了解决,因此我要感谢在此过程中对我帮助的老师和同学们,感谢指导老师帮助我选课题,给我做详细的讲解,给我提供设计所需要的各种设备,也经常询问我进度与成果,再有难点的时候给我解决思路,帮助我顺利完成。没有他的指导,也不会有我今天所展现出的成果。

首先我要感谢我的指导老师,指导老师在教学任务繁忙的情况下,抽出时间帮助我纠正我在设计当中出现的问题,并耐性地为我的论文作校正,是他的定期检查和指导使得我们的毕业设计高质量完成。他在我整个课题开发和设计的过程中,为程序的设计、框架的设计、代码的撰写方面以及论文框架的设计提供了很多宝贵的意见,并且为我推荐了许多有用的资料和文献,他的指导和建议使我受益匪浅,有了指导老师的辅导和指点,我论文才能够顺利完成。老师的认真负责的工作态度和治学严谨之道使我们这些即将踏入社会的毕业生受益匪浅。

然后要感谢我的同学们,感谢大家对我这次毕业设计的帮助, 也感谢大家在大学生活中对我的陪伴,使得我的大学生活过的很快乐。

另外,我还要感谢父母,感谢一直以来对我的支持,让我能够顺利的完成我的学业,没有你们也就没有我的今天,感谢你们无私的付出,未来我一定会报答你们的。

最后,感谢在座的所有参加我论文答辩的老师们,感谢大家的聆听,你们辛苦了。

免费领取项目源码,请关注点赞+私聊

spring boot小型仪器公司生产管理系统 毕业设计源码031853相关推荐

  1. 毕业设计 Spring Boot的公寓宿舍后勤管理系统(含源码+论文)

    文章目录 1 项目简介 2 实现效果 2.1 界面展示 3 设计方案 3.1 概述 3.2 系统流程 3.2.1 系统开发流程 3.2.2 系统操作流程 3.3 系统结构设计 4 项目获取 1 项目简 ...

  2. 毕业设计 Spring Boot的共享充电宝管理系统(含源码+论文)

    文章目录 1 项目简介 2 实现效果 2.1 界面展示 3 设计方案 3.1 概述 3.2 系统流程 3.2.1 系统开发流程 3.3 系统结构设计 4 项目获取 1 项目简介 Hi,各位同学好呀,这 ...

  3. 基于spring boot的奖助学金评审系统毕业设计源码031035

    奖助学金评审系统的设计与实现 摘 要 科技进步的飞速发展引起人们日常生活的巨大变化,电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用.信息时代的到来已成为不可阻挡的时尚潮流,人 ...

  4. spring boot企业网站设计与实现毕业设计源码211750

    Springboot企业网站的设计与实现 摘 要 二十世纪进入信息发展高速路,数码化革命给所有领域带来新的改变.随着电脑办公自动化的普及,电子商务应运而生,一切都归功于internet的巨大贡献,互联 ...

  5. spring boot社区养老医疗服务平台 毕业设计源码041148

    springboot社区养老医疗服务平台 摘 要 随着社会的发展,社会的各行各业都在利用信息化时代的优势.计算机的优势和普及使得各种信息系统的开发成为必需. 社区养老医疗服务平台,主要的模块包括查看首 ...

  6. spring boot跨境电商系统毕业设计源码211003

    摘 要 随着科学技术的飞速发展,各行各业都在努力与现代先进技术接轨,通过科技手段提高自身的优势:对于跨境电商系统当然也不能排除在外,随着网络技术的不断成熟,带动了跨境电商系统,它彻底改变了过去传统的管 ...

  7. 毕业设计 Spring Boot的网上租车管理系统(含源码+论文)

    文章目录 1 项目简介 2 实现效果 2.1 界面展示 3 设计方案 3.1 概述 3.2 系统流程 3.2.1 系统开发流程 3.2.2 登录流程 3.3 系统结构设计 4 项目获取 1 项目简介 ...

  8. JAVA计算机毕业设计伊伊物流公司的管理系统Mybatis+源码+数据库+lw文档+系统+调试部署

    JAVA计算机毕业设计伊伊物流公司的管理系统Mybatis+源码+数据库+lw文档+系统+调试部署 JAVA计算机毕业设计伊伊物流公司的管理系统Mybatis+源码+数据库+lw文档+系统+调试部署 ...

  9. 计算机毕业设计Java小型企业员工工资管理系统(源码+系统+mysql数据库+Lw文档)

    计算机毕业设计Java小型企业员工工资管理系统(源码+系统+mysql数据库+Lw文档) 计算机毕业设计Java小型企业员工工资管理系统(源码+系统+mysql数据库+Lw文档) 本源码技术栈: 项目 ...

最新文章

  1. 面试官灵魂的一击:你懂MySQL事务吗?
  2. 取消大小周的第一个周末,我吃了顿烤串
  3. JavaScript定时调用函数(SetInterval与setTimeout)
  4. 烂泥:高负载均衡学习haproxy之关键词介绍
  5. 数据中台实战入门篇:数据中台对内、对外合作机制
  6. airtest自动化测试_【游戏职业说】我在网易做测试开发(QA)
  7. DemoKit编译过程错误
  8. PHP如何判断图片是否伪造
  9. 小程序转发功能的实现(页面转发和按钮转发)
  10. Server2008如何卸载MySQL_「完美卸载」完美卸载SQL Server 2008 R2 的方法,适合所有问题 - seo实验室...
  11. 在不格式化U盘的情况下查杀U盘快捷方式病毒
  12. CAD制图神器-CAD专用键盘
  13. bootstrap-table实现表格编辑
  14. veu中时间转换----element-UI上Date-Picker时间控件
  15. gcc 中-O -O1 -O2 -O3 -Os -Ofast -Og优化的原理
  16. 单片机笔记五:改进无源蜂鸣片驱动电路
  17. 在STEAM上玩电路仿真
  18. Selenium + Python 自学笔记(第九天)
  19. ios隐私权限的使用及设置
  20. python定义一个数据自动去重的函数_110道Python面试题(真题小结)

热门文章

  1. k8s部署-31-k8s中如何进行资源隔离资源
  2. java毕业设计劳务外包管理系统源码+lw文档+mybatis+系统+mysql数据库+调试
  3. 怎样利用思维导图模板绘制思维导图?分享几款常用的思维导图模板
  4. 开发者要变现,广告平台哪家强?
  5. ubuntu14.04安装php5.6
  6. python表情符号编码_Emoji的编码以及常见问题处理
  7. 【实验三】LZW编解码算法实现与分析
  8. ACM模板(从小白到ACMer的学习笔记)
  9. 数字视频测量应用技术(基础篇)
  10. 重庆交通大学校园邮箱开通