基于java+springboot+vue的船舶维保管理系统

🙊作者简介:多年编程开发经验,专注java技术领域和毕业设计项目实战,系统定制、远程部署调试、代码讲解、代码修改
🍅擅长语言:springboot、ssm、vue、html、jsp、php、python、爬虫、小程序、安卓app
⬇️源码获取:文末可以获取源码+数据库+文档

 

⚡感兴趣的可以先收藏+关注,后续会更新更多项目资料,所有项目均配有开发文档和安装配置教程

2523d86d74544dbe93ab0908c5fea145.png

摘    要

传统信息的管理大部分依赖于管理人员的手工登记与管理,然而,随着近些年信息技术的迅猛发展,让许多比较老套的信息管理模式进行了更新迭代,船舶信息因为其管理内容繁杂,管理数量繁多导致手工进行处理不能满足广大用户的需求,因此就应运而生出相应的船舶维保管理系统。

本船舶维保管理系统分为管理员还有用户两个权限,管理员可以管理用户的基本信息内容,可以管理公告信息以及船舶信息,能够与用户进行相互交流等操作,用户可以查看船舶信息,可以查看公告以及查看管理员回复信息等操作。

该船舶维保管理系统采用的是WEB应用程序开发中最受欢迎的小程序结构模式,使用占用空间小但功能齐全的MySQL数据库进行数据的存储操作,系统开发技术使用到了JSP技术。该船舶维保管理系统能够解决许多传统手工操作的难题,比如数据查询耽误时间长,数据管理步骤繁琐等问题。总的来说,船舶维保管理系统性能稳定,功能较全,投入运行使用性价比很高。

 

关键词:船舶维保管理系统;MySQL数据库;SSM技术

 

 

 

第一章  课题背景及研究内容

 

1.1 课题背景

信息数据从传统到当代,是一直在变革当中,突如其来的互联网让传统的信息管理看到了革命性的曙光,因为传统信息管理从时效性,还是安全性,还是可操作性等各个方面来讲,遇到了互联网时代才发现能补上自古以来的短板,有效的提升管理的效率和业务水平。传统的管理模式,时间越久管理的内容越多,也需要更多的人来对数据进行整理,并且数据的汇总查询方面效率也是极其的低下,并且数据安全方面永远不会保证安全性能。结合数据内容管理的种种缺点,在互联网时代都可以得到有效的补充。结合先进的互联网技术,开发符合需求的软件,让数据内容管理不管是从录入的及时性,查看的及时性还是汇总分析的及时性,都能让正确率达到最高,管理更加的科学和便捷。本次开发的船舶维保管理系统实现了船舶管理、维修成本管理、船家管理、字典管理、公告管理、故障上报管理、维保公司管理、维保计划管理、维保人员管理、管理员管理等功能。系统用到了关系型数据库中王者MySql作为系统的数据库,有效的对数据进行安全的存储,有效的备份,对数据可靠性方面得到了保证。并且程序也具备程序需求的所有功能,使得操作性还是安全性都大大提高,让船舶维保管理系统更能从理念走到现实,确确实实的让人们提升信息处理效率。

1.2 开发目的和意义

小康时代的到来,使得人们满意度上升,生活各个方面都产生了许多变化,比如办公都有相应软件,很多工作都要求员工会操作计算机,可以说现在的时代基本被软件覆盖得差不多了,软件行业的特征就是大家都在使用软件代替传统手工记载操作,软件的出现让我们的生活还有工作又向前翻了新篇章。船舶维保管理系统是一个利用软件形式管理船舶信息的平台。管理员管理租车信息也不再需要用纸张进行信息记录及查询管理操作,所有的操作都是利用电脑进行办公,用户需要使用密码还有用户名进行系统登录操作,按照系统主页界面的各个功能展示进行相关操作,无论添加或者是删除,拟或是修改查询等操作,时间上不需要太多,短短几分钟就会搞定。况且软件是不限制办公地点以及办公时间的,只要有操作需要,随时随地登录系统就可以完成任务。办公效率提高这个不再是难题。公告租赁店对于租车信息的管理操作早就应该进行变革了,利用软件管理租车信息,节约人力物力成本,这是一个新的租车信息管理的创举。

1.3 论文研究内容

本次开发的船舶维保管理系统的论文从下面几个部分进行编写:

第一章:本章介绍了程序开发背景和目的意义,罗列出了论文写作内容信息,让我们知道论文编写是如何进展的。

第二章:本章主要讲解了系统开发用到的相关技术方面的知识,比如SSM技术,MySQL数据库知识等内容。帮助人们更好的理解系统技术上面的相关知识。

第三章:文章第3章主要介绍了系统开发的可行性问题,从经济,时间,操作等内容上面进行了大致介绍,确定系统开发确实可行,然后分析了系统的开发流程,确定系统需要具备的大概的功能,保障系统能够稳定使用和运行。

第四章:这个章节主要绘制出了系统功能架构,让我们更直观了解船舶维保管理系统的功能,对后台数据库表进行了设计,还画出了对应的E-R图。

第五章:这个章节主要介绍系统各个部分功能具体实现的界面效果。让我们了解到各个部分的功能详细情况。

第六章:这个部分主要就是对船舶维保管理系统进行整体测试,看看程序是否能够达到用户使用要求,程序能否进行验收上交操作。

 

 

 

 

 


第二章 相关技术

 

本次开发船舶维保管理系统使用的是Vue进行程序开发,船舶维保管理系统的数据信息选择MySQL数据库进行存放。

 

2.1 VUE介绍

Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。

2.2 MySQL数据库

开发的程序面向用户的只是程序的功能界面,让用户操作程序界面的各个功能,那么很多人就会问,用户使用程序功能生成的数据信息放在哪里的?这个就需要涉及到数据库的知识了,一般来说,程序开发通常就会对常用数据存储工具的特点进行分析比对,比如Mysql数据库的特点与优势,Access数据库的特点与优势,Sqlserver数据库的特点与优势等,最终看哪个数据库与需要开发的程序比较匹配,也符合程序功能运行需要的数据存储要求,比如,需要开发商业级别的程序,存储的数据对数据库要求较高,可以选用Oracle,如果只是比较简单的程序,对数据存储没有过多要求,可以选用微软旗下的Access,当开发程序要求数据库占用空间小,并能满足程序数据存储要求时,就可以考虑Oracle公司从瑞典MySQL AB公司在很早之前就收购过一个关系型数据库,它是现在的Mysql数据库。所以船舶维保管理系统后台数据库使用的是MySQL进行数据库方面的开发工作的,MySQL它是微软开发的一款平台软件,这个软件可以给用户提供高效率的智能数据,并且数据信息还是很可靠,使用它进行数据存储可以满足大众企业管理各种各样的数据信息的需求。MySQL在MySQL版本里面它是最全面的,也是最强大的开发平台, MySQL在许多关键之处都进行了改进的操作,它也增加了很多新特性,这些改进和更新让公司能够对关键应用程序进行高效运行,并且还可以让公司降低发送信息给用户的成本,以及降低数据信息管理的基础设施。因此MySQL在公司以及企业中它的地位是非常高的,ERP还有OA系统,以及公司财务的系统都离不开MySQL,在软件开发非常流行的今天,MySQL也被用来作为网站开发的网站后台数据库,可以说公司使用MySQL进行数据管理不仅节约成本,还可以让公司数据信息的管理效率大大提高,公司数据存放在MySQL平台上,数据信息的安全性也不用担心,因为MySQL他可以给数据库里面的日志还有数据文件以及整个数据库进行加密操作,另外MySQL还提供在线备份功能,这样可以节约存储空间,加快数据备份的速度。总之,选择MySQL进行在线系统的后台数据库开发是很有优势的。这是个不错的软件选择。

 

 

 


第三章 系统分析

 

3.1可行性分析

可行性分析从时间,经济以及操作和技术上面进行调查和研究,确保合理利用信息资源,避免在进行程序设计过程中因为考虑不周到所带来的困扰,帮助我们更好的进行程序设计。

3.1.1时间可行性

本次进行系统开发,我预留了两个月时间来完成,从系统的需求分析,功能结构设计,功能详细设计以及系统测试等环节,两个月时间是可以完成程序开发操作的,我打算每天早中晚都进行程序的编写操作,这期间也包括查阅各种资料信息,加上同学以及老师的帮助和指点,相信程序开发的时间也会缩短不少。所以时间上是可行的。

3.1.2 经济可行性

船舶维保管理系统的开发平台是IDEA,数据库选用MySQL数据库,使用的浏览器都是大众浏览器,这些软件是不需要收费就能进行下载安装操作的。在系统开发的硬件选择上面,我使用的是自己的笔记本进行开发操作。因此在进行系统开发时,经济上面无需额外支出。开发出来的程序可以提高办公效率,带来的经济效益比较高,系统开发的投入产出比很可观。

3.1.3 操作可行性

船舶维保管理系统的界面设计比较简单,界面布局根据用户日常使用习惯进行设计,网站各个功能在导航栏里面清晰可见,网站的数据操作可视化,用户操作网站不需要培训就能上手,只需要跟着网站功能提示进行操作就行。

3.1.4 技术可行性

作为计算机专业学生,在学校期间就学习到许多关于编程方面的知识,像SSM技术,还有MySQL数据库等知识,我对IDEA开发平台以及MySQL数据库的操作也比较熟练,所以技术上面还是有一定把握。

3.1.5 法律可行性

自己本人开发的软件和用到的资料来源都是图书馆以及百度文库和百度网页等渠道,并不涉及违法。在个人毕业设计上面,无论源代码还是论文编写内容不存在抄袭行为。

从上面的经济,操作以及时间上面进行的分析,得出结论就是这次开发的船舶维保管理系统在开发上面是能够进行的,系统开发出来能创造更大的经济效益,越早开发升值空间越大。

3.2系统流程分析

船舶维保管理系统的开发也是有对应的流程,开发之前必须要进行用户功能需求的分析,最后根据功能需求进行网站设计还有数据库相关数据的设计工作,此次开发的船舶维保管理系统开发流程如图3.1所示。

64cc15a382c6453ea59a96cbf0e5d5ea.png

图3.1 程序操作流程图

系统开发完成之后会给用户提供登录入口,在这个界面用户输入的信息会得到验证,通过验证之后才能进去船舶维保管理系统的访问主界面,系统登录执行流程如下:

fcf9111655aa4bbd82b0664d9513c8a5.png

图3.2 系统执行流程图

3.3系统功能需求分析

系统的开发离不开前期的需求分析,这个阶段就是让程序员知道自己该做什么事情,在进行需求分析的时候,着重点就是用户对系统的功能要求,这个阶段要是分析得很到位,系统开发出来投入使用时,用户就会发现系统的功能跟用户需求保持一致,程序稳定性也是达标的,可以说需求分析是决定系统开发成败的关键,它主要就是把现实世界进行抽象化,然后把抽象化的对象用来构建模型。

船舶维保管理系统的受益群体主要是工作人员,该网站能够方便使用者进行数据信息的查找和管理工作,本次开发的网站我们设计的界面展示主要分为管理员界面以及用户界面,具体界面的功能分布如下。

船舶维保管理系统管理员可以管理用户的基本信息,可以管理公告信息,可以管理公告信息等。

3.4 系统非功能需求分析

(1)完整性需求

本次开发的船舶维保管理系统里面记录的数据信息不能保持为空,并且数据信息一定要核对正确才行,系统里面数据之间存在的联系不能出错,不能够张冠李戴,数据表里面同一数据在不同数据表里面的显示内容要一样。

(2)性能需求

用户在操作船舶维保管理系统的各个部分内容时,弹出的页面响应时间不能太长,最好控制在三秒钟以内,最大限制值就是四秒,这个是给用户一个好的程序体验。并且系统还要能够承载多人同时在线进行船舶维保管理系统的访问操作。

(3)界面需求

船舶维保管理系统界面设计上面应该考虑到用户日常操作习惯,比如导航栏的设计不能在右边,这个完全违背了用户使用网站的操作习惯,同时功能导航的字体以及颜色应该比较显眼,方便用户容易找寻,避免用户在进行功能操作上面浪费太多时间。

(4)安全性需求

船舶维保管理系统的安全性要有保证,给用户一种可靠,可以信赖的感觉,系统在运行过程中,不能总是出错,与用户进行功能界面交互时,要及时给出反馈信息,另外系统要设置登录窗口,让不是系统的用户不可以进行系统功能界面的访问操作。系统用户也要经过用户名密码的填写操作,才可以进入系统主界面,这样就可以保障系统数据信息处于一种安全状态。

 

 

 


第四章 系统设计

 

4.1 总体功能

船舶维保管理系统是根据需求定制开发,开发软件选用IDEA平台配合MySQL数据库进行开发环境的搭建操作,网站采用WEB应用程序中最流行的小程序结构进行开发,用户访问系统数据仅仅需要在客户端安装谷歌浏览器或者是当下常用浏览器就可以访问网站内容。

 4.2 系统模块设计

船舶维保管理系统系统在进行系统中功能模块的划分时,采用层次图来进行表示。层次图具有树形结构,它能使用矩形框来描绘数据信息。顶层代表的数据结构很完整,顶层下面的矩形框表示的数据就是子集数据,当然处于最下面的矩形框就是不能再进行细分的数据元素了,使用层次方框图描述系统功能能让用户一目了然,能够明白系统的功能,以及对应功能板块下面的子功能都可以清楚领会。船舶维保管理系统分为管理员和用户两部分操作角色,下面将对他们的功能进行阐述。

管理员可以管理用户的基本信息,可以管理等功能。管理员功能结构图如下:

0dc369aa4c3d44649554d6206f77a25a.png

图4.1 管理员功能结构图

 

4.3 数据库设计

4.3.1 数据库设计

数据库设计它是建立在数据库还有它对应的应用系统的一门技术,只要是信息系统开发还有系统建设,都会用到数据库设计,但是这个数据库设计并不是很简单就可以完成的,设计期间会遇到很多麻烦事,在设计期间需要考虑再考虑,逐步完善。主要内容也就是把数据库里面的对象还有对象之间的联系进行系统规划操作,还有把他们结构化的过程。

4.3.2 数据库E-R 图

E-R 图分成三部分内容,分别是实体,实体的属性以及实体之间的关系这三个部分的内容,通常长方形表示的就是实体,椭圆形表示的就是属性,菱形表示的就是关系了。在E-R 图里面,实体就是对象,比如学生,人,音乐等都能代表实体,实体都具备自己的成员,比如张三就是学生实体里面的成员。一个学生会具有自己的姓名,年龄,出生日期等信息,这些信息就是学生这个实体的属性,因此E-R 图属性代表的就是数据对象具备的属性,E-R 图的关系就是实体跟实体之间的关系了,比如学生跟课程会存在一定的关系,这种关系使用菱形进行表示。

(1)下图是公告实体和其具备的属性。

842c3c8fa98147f6bc050785f1918010.png

公告实体属性图

(2)下图是维修成本实体和其具备的属性。

4506344e4b1f41b599832ef9360b864a.png

维修成本实体属性图

(3)下图是维保计划实体和其具备的属性。

bc5d03377766403eb004e573f65c5532.png

维保计划实体属性图

(4)下图是故障上报实体和其具备的属性。

de05a69d6817495d9707915d8991eb42.png

故障上报实体属性图

(5)下图是维保人员实体和其具备的属性。

f0047453ffe248bea7d7bc23cf4a2b14.png

维保人员实体属性图

(6)下图是船舶实体和其具备的属性。

8cd589f4384546cbad1c14fed3f31f0b.png

船舶实体属性图

(7)下图是船家实体和其具备的属性。

9bcabae83f36464ba9a6fc3253c3584d.png

船家实体属性图

(8)下图是维保公司实体和其具备的属性。

4ff265c78f4a4e918a9ed2ab09e2d1ba.png

维保公司实体属性图

 

 

 

 

 

 

 

4.3.3 数据库表设计

数据库里面的数据表存放的就是各种数据记录,我们在进行系统增删改查操作时,其实也是在对应数据表里面进行的增删改查操作,一个好的数据库能够缩短信息处理时间,所以说数据库的设计工作不容小觑,数据库里面设置哪些表,表里面的字段设计以及字段类型和字段长度等信息都要考虑周到才行,比如时间这个字段,它的数据类型就不能是int型,不然在系统操作中就会弹出输入数据格式不符合要求的报错提示。下面简单介绍船舶维保管理系统的一些数据表。

表4.1船舶表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

chuanjia_id

Integer

船家

3

weibaogongsi_id

Integer

维保公司

4

chaunbo_uuid_number

String

船舶编号

5

chaunbo_name

String

船舶名字

6

chaunbo_photo

String

船舶照片

7

chaunbo_file

String

附件

8

chaunbo_types

Integer

船舶类型

9

chaunbo_zhuangtai_types

Integer

船舶状态

10

chaunbo_content

String

船舶介绍

11

insert_time

Date

上传时间

12

create_time

Date

创建时间

表4.2维修成本表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

guzhang_id

Integer

故障

3

chengben_uuid_number

String

维修成本编号

4

chengben_types

Integer

维修成本类型

5

chengben_file

String

附件

6

chengben_jine

BigDecimal

金额

7

chengben_time

Date

花费时间

8

chengben_content

String

备注

9

insert_time

Date

录入时间

10

create_time

Date

创建时间

表4.3船家表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

chuanjia_uuid_number

String

船家编号

3

chuanjia_name

String

船家姓名

4

chuanjia_phone

String

船家手机号

5

chuanjia_id_number

String

船家身份证号

6

chuanjia_photo

String

船家头像

7

chuanjia_email

String

船家邮箱

8

jinyong_types

Integer

账户状态

9

create_time

Date

创建时间

表4.4字典表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

dic_code

String

字段

3

dic_name

String

字段名

4

code_index

Integer

编码

5

index_name

String

编码名字

6

super_id

Integer

父字段id

7

beizhu

String

备注

8

create_time

Date

创建时间

表4.5公告表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

gonggao_name

String

公告名称

3

gonggao_photo

String

公告图片

4

gonggao_types

Integer

公告类型

5

insert_time

Date

发布时间

6

gonggao_content

String

公告详情

7

create_time

Date

创建时间

表4.6故障上报表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

chaunbo_id

Integer

船舶

3

weibaorenyuan_id

Integer

维保人员

4

guzhang_uuid_number

String

故障编号

5

guzhang_name

String

故障标题

6

guzhang_photo

String

故障照片

7

guzhang_address

String

故障位置

8

guzhang_types

Integer

故障类型

9

guzhang_content

String

故障内容

10

guzhang_zhuangtai_types

Integer

故障状态

11

insert_time

Date

报修时间

12

guzhang_text

String

维修评价

13

create_time

Date

创建时间

表4.7维保公司表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

weibaogongsi_uuid_number

String

维保公司编号

3

weibaogongsi_name

String

维保公司名称

4

weibaogongsi_fuzeren

String

负责人

5

weibaogongsi_phone

String

维保公司手机号

6

weibaogongsi_photo

String

公司logo

7

weibaogongsi_address

String

公司位置

8

jinyong_types

Integer

账户状态

9

create_time

Date

创建时间

表4.8维保计划表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

chaunbo_id

Integer

船舶

3

weibaogongsi_id

Integer

维保公司

4

weibaorenyuan_id

Integer

维保人员

5

weibaojihua_uuid_number

String

维保计划编号

6

weibaojihua_name

String

维保计划标题

7

weibaojihua_file

String

维保计划附件

8

weibaojihua_types

Integer

维保计划类型

9

weibaojihua_buwei

String

维保部位

10

weibao_time

Date

维保时间

11

weibaojihua_address

String

维保地点

12

weibaojihua_content

String

维保详情

13

insert_time

Date

上传时间

14

weibaojihua_yesno_types

Integer

申请状态

15

weibaojihua_yesno_text

String

审核意见

16

weibaojihua_shenhe_time

Date

审核时间

17

create_time

Date

创建时间

表4.9维保人员表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

weibaogongsi_id

Integer

维保公司

3

weibaorenyuan_uuid_number

String

维保人员编号

4

weibaorenyuan_name

String

维保人员姓名

5

weibaorenyuan_phone

String

维保人员手机号

6

weibaorenyuan_id_number

String

维保人员身份证号

7

weibaorenyuan_photo

String

维保人员头像

8

weibaorenyuan_email

String

维保人员邮箱

9

jinyong_types

Integer

账户状态

10

create_time

Date

创建时间

表4.10管理员表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

username

String

学生名

3

password

String

密码

4

role

String

角色

5

addtime

Date

新增时间

 

第五章 系统实现

 

5.1 管理员功能模块的实现

5.1.1 船舶列表

如图5.1显示的就是船舶列表页面,此页面提供给管理员的功能有:查看船舶、新增船舶、修改船舶、删除船舶等。

f8e04ddcf0da4f6ba4e95c04bf37c59e.png

图5.1 船舶列表页面

5.1.2 公告信息管理

管理员可以对公告信息进行管理,可以新增公告信息,修改公告信息,删除无效的公告信息。公告信息管理界面如图5.2所示。

5e6ca407b1e149f0b6974658235c6809.png

图5.2 公告信息管理页面

5.1.3 公告类型管理

公告类型管理页面显示所有公告类型,在此页面既可以让管理员添加新的公告信息类型,也能对已有的公告类型信息执行编辑更新,失效的公告类型信息也能让管理员快速删除。下图就是公告类型管理页面。公告类型管理界面如图5.3所示。

606ceeb7e40f48379a4f45975f94d9c5.png

图5.3公告类型管理界面

5.1.4 维保计划管理

如图5.4显示的就是维保计划管理页面,此页面提供给管理员的功能有:新增维保计划,修改维保计划,删除维保计划。

ec9da2a9f44747e1a881d254d89c783b.png

图5.4维保计划管理页面

5.1.5 维保计划类型管理

如图5.5显示的就是维保计划类型管理页面,此页面提供给管理员的功能有:新增维保计划类型,修改维保计划类型,删除维保计划类型。

97fcdb2fc8e8450e9cbb048b0eb78d94.png

图5.5 维保计划类型管理页面


第六章 系统测试

程序软件一旦被开发完成之后,在真正投入日常生活中进行运行使用之前,是必须要经历测试这一个重要的操作环节,因为开发期间注重的是每个单独功能模块的开发,尽管每次开发完成一个单独功能模块时,会通过单元测试进行检验,检验合格才会让程序员继续开发下一个子功能模块,以此类推,当程序员完成所有的系统子功能模块的开发时,这个时候就需要引进系统测试,系统测试就是把所有的子功能模块集成到一起,构建成整个系统,在指定的运行环境下进行运行,主要就是测试系统的所有功能模块在一起是否良好运行,一旦程序软件通过了系统测试这一环节,就意味着它可以进行最终的验收测试了,这个测试步骤的操作用户是程序面向的客户或者是最终用户了。

6.1软件测试

软件测试包括的对象有详细设计,开发出来的软件的运行环境,软件的需求以及软件的源代码内容等,软件测试也包括了五个要素,分别是软件的质量,技术,人员还有流程以及资源这几个要素。软件测试的目标包含了测试的覆盖率信息还有测试效率信息。一般来说,软件测试主要分成了单元测试,集成测试以及系统测试和验收测试这四个阶段的内容,下面将分别进行相关阐述。

单元测试:这个部分需要涉及到程序的代码方面的知识,这个操作环节是程序的开发者进行的,当程序开发者通过代码编写程序的子功能模块时,就会进行单元级别的测试,通常这个环节的测试也会被称作是白盒测试。

集成测试:这个步骤的前提是程序的所有功能模块都已完成开发,这个时候需要把程序所有的子功能模块集成到一起,形成一个完整的系统,此测试的主要目的就是检查这些功能模块集成在一起时的兼容性,也就是检测它们是否按照预期正常运行。

系统测试:当程序测试进入到这个环节时,就意味着程序测试工作已经进行到一半了,这个部分的测试也有另外一个名字,称作是黑盒测试,主要用于测试系统的功能是否按照预期进行运行。

验收测试:开发的程序已经通过了前面的单元测试,集成测试,以及系统测试环节时,就需要进行验收了,这个环节的操作用户就是程序面临的最终用户或者是客户。测试主要目的就是验证开发完成的程序是不是能够符合用户对其的期望,以及程序的所有功能是否符合用户的真正需求。

 

6.2测试环境

船舶维保管理系统的测试选用的测试平台是IDEA平台环境,测试时首先需要用户打开MySQL数据库进行数据库文件的附加操作,然后打开IDEA,选择文件打开网站,把船舶维保管理系统的程序添加进入IDEA平台中,接着把文件部署到tomcat服务器里面,最后运行程序,这时用户可以操作系统里面的各个功能,看看程序有没有达到用户的要求。

6.3 测试用例 

6.3.1 用户登录测试

用户登录需要的信息包含登录名称还有对应密码,输入数据信息都正确了才能进行系统访问处理。用户登录测试过程如表6.1所示:

表6.1  用户登录测试表

测试目的

操作流程

测试用例

预测结果

测试结果

用户登录

填写用户名密码,点击首页登录按钮

错误填写用户名还有密码

登录失败

提示错误信息

正确填写用户名和密码

登录成功

登录成功

 6.4.2 添加公告类别测试

管理员可以在添加公告类别界面输入公告类别名称信息,如果数据信息为空,系统会给出相应提示。只有所有的数据信息都合理输入,管理员才能完成公告类别的添加操作。测试数据见下表:

表6.2添加公告类别测试表

测试项目

操作流程

测试用例

预测结果

测试结果

添加公告类别

管理员登陆后点击添加公告类别按钮,添加公告类别信息

类别名称为空

添加失败,弹出提示按钮

添加失败,提示请填写内容

合理填写类别名称

添加成功

添加成功

 

6.5测试结果

经过此次对船舶维保管理系统的综合性测试,我们不难发现程序的功能并没有出现明显的逻辑性错误,用户在进行功能操作时,程序基本能根据用户操作情况给出相应的反馈。程序质量以及可靠性在系统的反复测试中都经过了严格检验,程序投入生活使用完全没有问题。

 

 

 


结  论

 

船舶维保管理系统的开发制作,从题目确定到成品完成,自己投入的精力与心血是非常多的。从船舶维保管理系统的前台页面实现,到船舶维保管理系统的后台代码的编辑,我用到的软件包括了数据库软件Mysql,Java开发工具IDEA,办公软件Office,浏览器软件Fireworks,图像处理软件Photoshop等,这也是我第一次使用Java语言,开发的这个比较简单的船舶维保管理系统。

开发船舶维保管理系统让我明白知识理论与现实实践的差距还是挺大的,很多时候,我们在学习课程知识的时候,都感觉书本上的内容,老师一点就通,然而这次毕设就真正考验了我,原来理论知识和现实实践完全是两码事,开发船舶维保管理系统一方面让我对在校学习的知识起了一个巩固作用,另一方面让我明白独立学习知识的重要性。在毕设作品完成期间,我才知道要开发一款软件需要经历很多繁琐的步骤,从开始的选题到系统需求分析以及功能板块的设计,还有系统详细实现以及系统测试,每个环节看似简单,其实暗藏很多知识点,这些都需要自己去网上或者是学校的图书馆查阅相对应的资料。每个环节都需要认真对待,要是系统需求分析没有做好,那么在系统设计与实现过程中就会出现很多错误,要么功能不全,要么就是程序开发出来根本不符合用户要求,所以程序的开发是一个知识再造的过程,一个人独自开发完一款软件也就深知这其间的各种不易了。

本次开发的系统整体界面还是比较清晰简明,功能上面考虑得比较全,几乎可以满足用户使用要求。尽管我对这次的毕设付出了许多的努力,但是程序还是有很多不足的地方,系统界面整体感觉还行,但是字体字号的选取上面还是有些不符合现实审美,在程序的CSS样式编码上面,我还有许多不熟悉的地方,虽然经过反复的测试与调试选中了现在这样的程序界面,但是我还是明显感觉到自己对一些常用CSS样式的不熟悉,编码过程中,我还要多次进行资料查看才知道。另外我编写的代码写作不是很规范,可读性比较差,幸运的是,我最终还是实现了系统中所要求的功能。

实践出真知,但是知识也是通过实践变得更加深刻,这次作品制作,让自己的专业知识水平与解决问题的能力得到了提高。也让自己更加明白活到老学到老的真正含义。

总的说来,这次编写毕业设计作品,我真正锻炼了自己的实际操作能力,以前只知道理论知识,现在通过实践,我对理论知识的认识变得更加深刻,由于编写程序时间比较短暂,程序开发期间遇到过很多坎坷,但最后都通过老师还有同学帮忙解决了,可以说这次的毕设作品进展得还算顺利。

 

 

 

 

 

 


参考文献

 

[1]刘媛春,罗云翔.基于JSP的动态网页技术[J].成都信息工程学院学报,2015(04):398-401.

[2]张波,张福炎.基于JSP技术的Web应用程序的开发[J].计算机应用研究,2011(05):99-101.

[3]杨馥显,刘嘉勇.基于JSP的数据库开发技术研究[J].通信技术,2011,44(03):51-53.

[4]靳其兵,李晓波.基于JSP的数据库连接技术的研究[J].计算机仿真,2015(04):108-111.

[5]罗建华.浅析JSP开发技术的现状与发展前景[J].电脑与电信,2011(09):62-63+66.

[6]林财兴,罗建,王晨林.基于JSP的管理信息系统的设计与实现[J].计算机应用研究,2011(09):105-107.

[7]李现艳,赵书俊,初元萍.基于MySQL的数据库服务器性能测试[J].核电子学与探测技术,2011,31(01):48-52.

[8]兰旭辉,熊家军,邓刚.基于MySQL的应用程序设计[J].计算机工程与设计,2014(03):442-443+468.

[9]张士军,陆海伦.索引在MySQL查询优化中的应用[J].计算机与数字工程,2017(01):37-39+8.

[10]余震.MySQL数据库对并发事件的控制和处理[J].电脑知识与技术,2013,9(34):7672-7674.

[11]李云云.浅析小程序体系结构[J].科学之友,2011(01):6-8.

[12]李书杰,李志刚.小程序三层体系结构模式[J].河北理工学院学报,2012(S1):25-28+34.

[13]刘小华,化琼珍.船舶维保管理系统的构建[J].物流技术与应用,2015(03):100-101.

[14]王锋.船舶维保管理系统构建的研究[J].商场现代化,2016(24):35-36.

[15]王育才.船舶维保管理系统构建的分析[J].中国管理信息化,2017,20(22):54-55.

 

 

 

 

 

 

 

 


致  谢

 

完成毕业设计也就意味着我离毕业不远了,想到自己即将离开学校,正式步入社会参加工作,内心还是挺舍不得学校的这些同学们还有老师,大学几年来,老师们每天给我们传授知识,让我们不断成长,身边的同学们,我们经常一起上下课,经常互相讨论问题,一起度过许多美好的时光,还有我的舍友们,每天的朝夕相处,我们总是有福同享,有难同当,在宿舍就是我们最美好的日子。即将毕业,在这里我想对我的老师们说声谢谢,谢谢你们给我们传授各种知识,让我们懂得更多的知识,还有我身边的同学们,祝福你们事业有成,工作顺利。祝愿给我们提供良好环境的大学校园能够创造出更加辉煌的前景。

 

 

 

核心代码


package com.controller;

import java.io.File;
import java.math.BigDecimal;
import java.net.URL;
import java.text.SimpleDateFormat;
import com.alibaba.fastjson.JSONObject;
import java.util.*;
import org.springframework.beans.BeanUtils;
import javax.servlet.http.HttpServletRequest;
import org.springframework.web.context.ContextLoader;
import javax.servlet.ServletContext;
import com.service.TokenService;
import com.utils.*;
import java.lang.reflect.InvocationTargetException;

import com.service.DictionaryService;
import org.apache.commons.lang3.StringUtils;
import com.annotation.IgnoreAuth;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.entity.*;
import com.entity.view.*;
import com.service.*;
import com.utils.PageUtils;
import com.utils.R;
import com.alibaba.fastjson.*;

/**
 * 船舶
 * 后端接口
 * @author
 * @email
*/
@RestController
@Controller
@RequestMapping("/chaunbo")
public class ChaunboController {
    private static final Logger logger = LoggerFactory.getLogger(ChaunboController.class);

    private static final String TABLE_NAME = "chaunbo";

    @Autowired
    private ChaunboService chaunboService;


    @Autowired
    private TokenService tokenService;

    @Autowired
    private ChengbenService chengbenService;//维修成本
    @Autowired
    private ChuanjiaService chuanjiaService;//船家
    @Autowired
    private DictionaryService dictionaryService;//字典
    @Autowired
    private GonggaoService gonggaoService;//公告
    @Autowired
    private GuzhangService guzhangService;//故障上报
    @Autowired
    private WeibaogongsiService weibaogongsiService;//维保公司
    @Autowired
    private WeibaojihuaService weibaojihuaService;//维保计划
    @Autowired
    private WeibaorenyuanService weibaorenyuanService;//维保人员
    @Autowired
    private UsersService usersService;//管理员


    /**
    * 后端列表
    */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params, HttpServletRequest request){
        logger.debug("page方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));
        String role = String.valueOf(request.getSession().getAttribute("role"));
        if(false)
            return R.error(511,"永不会进入");
        else if("船家".equals(role))
            params.put("chuanjiaId",request.getSession().getAttribute("userId"));
        else if("维保公司".equals(role))
            params.put("weibaogongsiId",request.getSession().getAttribute("userId"));
        else if("维保人员".equals(role))
            params.put("weibaorenyuanId",request.getSession().getAttribute("userId"));
        CommonUtil.checkMap(params);
        PageUtils page = chaunboService.queryPage(params);

        //字典表数据转换
        List<ChaunboView> list =(List<ChaunboView>)page.getList();
        for(ChaunboView c:list){
            //修改对应字典表字段
            dictionaryService.dictionaryConvert(c, request);
        }
        return R.ok().put("data", page);
    }

    /**
    * 后端详情
    */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id, HttpServletRequest request){
        logger.debug("info方法:,,Controller:{},,id:{}",this.getClass().getName(),id);
        ChaunboEntity chaunbo = chaunboService.selectById(id);
        if(chaunbo !=null){
            //entity转view
            ChaunboView view = new ChaunboView();
            BeanUtils.copyProperties( chaunbo , view );//把实体数据重构到view中
            //级联表 船家
            //级联表
            ChuanjiaEntity chuanjia = chuanjiaService.selectById(chaunbo.getChuanjiaId());
            if(chuanjia != null){
            BeanUtils.copyProperties( chuanjia , view ,new String[]{ "id", "createTime", "insertTime", "updateTime", "chuanjiaId"
, "weibaogongsiId"});//把级联的数据添加到view中,并排除id和创建时间字段,当前表的级联注册表
            view.setChuanjiaId(chuanjia.getId());
            }
            //级联表 维保公司
            //级联表
            WeibaogongsiEntity weibaogongsi = weibaogongsiService.selectById(chaunbo.getWeibaogongsiId());
            if(weibaogongsi != null){
            BeanUtils.copyProperties( weibaogongsi , view ,new String[]{ "id", "createTime", "insertTime", "updateTime", "chuanjiaId"
, "weibaogongsiId"});//把级联的数据添加到view中,并排除id和创建时间字段,当前表的级联注册表
            view.setWeibaogongsiId(weibaogongsi.getId());
            }
            //修改对应字典表字段
            dictionaryService.dictionaryConvert(view, request);
            return R.ok().put("data", view);
        }else {
            return R.error(511,"查不到数据");
        }

    }

    /**
    * 后端保存
    */
    @RequestMapping("/save")
    public R save(@RequestBody ChaunboEntity chaunbo, HttpServletRequest request){
        logger.debug("save方法:,,Controller:{},,chaunbo:{}",this.getClass().getName(),chaunbo.toString());

        String role = String.valueOf(request.getSession().getAttribute("role"));
        if(false)
            return R.error(511,"永远不会进入");
        else if("船家".equals(role))
            chaunbo.setChuanjiaId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));
        else if("维保公司".equals(role))
            chaunbo.setWeibaogongsiId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));

        Wrapper<ChaunboEntity> queryWrapper = new EntityWrapper<ChaunboEntity>()
            .eq("chuanjia_id", chaunbo.getChuanjiaId())
            .eq("weibaogongsi_id", chaunbo.getWeibaogongsiId())
            .eq("chaunbo_name", chaunbo.getChaunboName())
            .eq("chaunbo_types", chaunbo.getChaunboTypes())
            .eq("chaunbo_zhuangtai_types", chaunbo.getChaunboZhuangtaiTypes())
            ;

        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        ChaunboEntity chaunboEntity = chaunboService.selectOne(queryWrapper);
        if(chaunboEntity==null){
            chaunbo.setInsertTime(new Date());
            chaunbo.setCreateTime(new Date());
            chaunboService.insert(chaunbo);
            return R.ok();
        }else {
            return R.error(511,"表中有相同数据");
        }
    }

    /**
    * 后端修改
    */
    @RequestMapping("/update")
    public R update(@RequestBody ChaunboEntity chaunbo, HttpServletRequest request) throws NoSuchFieldException, ClassNotFoundException, IllegalAccessException, InstantiationException {
        logger.debug("update方法:,,Controller:{},,chaunbo:{}",this.getClass().getName(),chaunbo.toString());
        ChaunboEntity oldChaunboEntity = chaunboService.selectById(chaunbo.getId());//查询原先数据

        String role = String.valueOf(request.getSession().getAttribute("role"));
//        if(false)
//            return R.error(511,"永远不会进入");
//        else if("船家".equals(role))
//            chaunbo.setChuanjiaId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));
//        else if("维保公司".equals(role))
//            chaunbo.setWeibaogongsiId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));
        if("".equals(chaunbo.getChaunboPhoto()) || "null".equals(chaunbo.getChaunboPhoto())){
                chaunbo.setChaunboPhoto(null);
        }
        if("".equals(chaunbo.getChaunboFile()) || "null".equals(chaunbo.getChaunboFile())){
                chaunbo.setChaunboFile(null);
        }
        if("".equals(chaunbo.getChaunboContent()) || "null".equals(chaunbo.getChaunboContent())){
                chaunbo.setChaunboContent(null);
        }

            chaunboService.updateById(chaunbo);//根据id更新
            return R.ok();
    }



    /**
    * 删除
    */
    @RequestMapping("/delete")
    public R delete(@RequestBody Integer[] ids, HttpServletRequest request){
        logger.debug("delete:,,Controller:{},,ids:{}",this.getClass().getName(),ids.toString());
        List<ChaunboEntity> oldChaunboList =chaunboService.selectBatchIds(Arrays.asList(ids));//要删除的数据
        chaunboService.deleteBatchIds(Arrays.asList(ids));

        return R.ok();
    }


    /**
     * 批量上传
     */
    @RequestMapping("/batchInsert")
    public R save( String fileName, HttpServletRequest request){
        logger.debug("batchInsert方法:,,Controller:{},,fileName:{}",this.getClass().getName(),fileName);
        Integer chuanjiaId = Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId")));
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        //.eq("time", new SimpleDateFormat("yyyy-MM-dd").format(new Date()))
        try {
            List<ChaunboEntity> chaunboList = new ArrayList<>();//上传的东西
            Map<String, List<String>> seachFields= new HashMap<>();//要查询的字段
            Date date = new Date();
            int lastIndexOf = fileName.lastIndexOf(".");
            if(lastIndexOf == -1){
                return R.error(511,"该文件没有后缀");
            }else{
                String suffix = fileName.substring(lastIndexOf);
                if(!".xls".equals(suffix)){
                    return R.error(511,"只支持后缀为xls的excel文件");
                }else{
                    URL resource = this.getClass().getClassLoader().getResource("static/upload/" + fileName);//获取文件路径
                    File file = new File(resource.getFile());
                    if(!file.exists()){
                        return R.error(511,"找不到上传文件,请联系管理员");
                    }else{
                        List<List<String>> dataList = PoiUtil.poiImport(file.getPath());//读取xls文件
                        dataList.remove(0);//删除第一行,因为第一行是提示
                        for(List<String> data:dataList){
                            //循环
                            ChaunboEntity chaunboEntity = new ChaunboEntity();
//                            chaunboEntity.setChuanjiaId(Integer.valueOf(data.get(0)));   //船家 要改的
//                            chaunboEntity.setWeibaogongsiId(Integer.valueOf(data.get(0)));   //维保公司 要改的
//                            chaunboEntity.setChaunboUuidNumber(data.get(0));                    //船舶编号 要改的
//                            chaunboEntity.setChaunboName(data.get(0));                    //船舶名字 要改的
//                            chaunboEntity.setChaunboPhoto("");//详情和图片
//                            chaunboEntity.setChaunboFile(data.get(0));                    //附件 要改的
//                            chaunboEntity.setChaunboTypes(Integer.valueOf(data.get(0)));   //船舶类型 要改的
//                            chaunboEntity.setChaunboZhuangtaiTypes(Integer.valueOf(data.get(0)));   //船舶状态 要改的
//                            chaunboEntity.setChaunboContent("");//详情和图片
//                            chaunboEntity.setInsertTime(date);//时间
//                            chaunboEntity.setCreateTime(date);//时间
                            chaunboList.add(chaunboEntity);


                            //把要查询是否重复的字段放入map中
                                //船舶编号
                                if(seachFields.containsKey("chaunboUuidNumber")){
                                    List<String> chaunboUuidNumber = seachFields.get("chaunboUuidNumber");
                                    chaunboUuidNumber.add(data.get(0));//要改的
                                }else{
                                    List<String> chaunboUuidNumber = new ArrayList<>();
                                    chaunboUuidNumber.add(data.get(0));//要改的
                                    seachFields.put("chaunboUuidNumber",chaunboUuidNumber);
                                }
                        }

                        //查询是否重复
                         //船舶编号
                        List<ChaunboEntity> chaunboEntities_chaunboUuidNumber = chaunboService.selectList(new EntityWrapper<ChaunboEntity>().in("chaunbo_uuid_number", seachFields.get("chaunboUuidNumber")));
                        if(chaunboEntities_chaunboUuidNumber.size() >0 ){
                            ArrayList<String> repeatFields = new ArrayList<>();
                            for(ChaunboEntity s:chaunboEntities_chaunboUuidNumber){
                                repeatFields.add(s.getChaunboUuidNumber());
                            }
                            return R.error(511,"数据库的该表中的 [船舶编号] 字段已经存在 存在数据为:"+repeatFields.toString());
                        }
                        chaunboService.insertBatch(chaunboList);
                        return R.ok();
                    }
                }
            }
        }catch (Exception e){
            e.printStackTrace();
            return R.error(511,"批量插入数据异常,请联系管理员");
        }
    }




}

 

 

  • 25
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值