目录
一、摘要
1.1 项目介绍
快递管理系统包含的快递区域模块、快递货架模块、快递类型模块和快递档案模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,快递管理系统基于角色的访问控制,给快递管理员和快递工作人员使用,可将权限精确到按钮级别,您可以自定义角色并分配权限,系统适合设计精确的权限约束需求。
-
前端:Vue 2.7.10
-
后端:Spring Boot 3.1.10
-
数据库:MySQL 8.0.31
1.2 项目录屏
二、研究内容
本课题的目的就是旨在开发一个为高校师生提供快递支持的快递管理系统。
快递管理系统主要采用了JAVA编程语言,采用了Vue的开发技术,使用MYSQL数据库来支撑系统的数据流动。
本文将最终完成快递管理系统设计与实现,并通过完备的功能测试和性能测试来验证该系统的质量。系统需要支持以下功能。
- 快递包装类型管理,实现增加、删除、修改、条件查询、导入快递包装类型。
- 快递管理,实现增加、删除、修改、条件查询、导入快递,支持上传快递图片。
- 快递区域管理,如大型快递包装、小型快递包装等,实现增加、删除、修改、条件查询快递区域。
- 快递货架管理,实现增加、删除、修改、条件查询快递货架。
- 用户档案管理,实现对终端用户数据的维护。
- 角色管理,采用基于角色的访问控制,对于快递管理员、仓管员、顾客分配不同的菜单权限。
拟解决的主要问题如下:
- 如何实现快递区域和快递的档案管理、快递回收记录存档;
- 系统如何应对用户的高并发访问,如何确保快递管理系统的安全性。
快递管理系统的功能性需求主要包含数据中心模块、快递包装类型模块、快递区域模块、快递货架模块、快递档案模块这五大模块,系统是基于浏览器运行的web管理后端,其中各个模块详细说明如下。
2.1 数据中心模块
数据中心模块包含了快递管理系统的系统基础配置,如登录用户的管理、运营公司组织架构的管理、用户菜单权限的管理、系统日志的管理、公用文件云盘的管理。
其中登录用户管理模块,由管理员负责运维工作,管理员可以对登录用户进行增加、删除、修改、查询操作。
组织架构,指的是运营公司的组织架构,该模块适用于管理这些组织架构的部门层级和员工的部门归属情况。
用户菜单权限管理模块,用于管理不同权限的用户,拥有哪些具体的菜单权限。
系统日志的管理,用于维护用户登入系统的记录,方便定位追踪用户的操作情况。
公用云盘管理模块,用于统一化维护快递管理系统中的图片,如快递单照片、快递区域照片等等。
2.2 快递类型模块
不同的快递有不同的快递类型,可以分为大快递、小快递、易碎快递、加急件快递等等,不同类型的快递有着不同的运输方式,所以需要建立快递类型模块,对快递类型数据进行维护。其中字段包括类型名称、状态、排序值、备注、创建人、创建时间、更新人、更新时间等,快递管理员可以新增、删除、修改、条件查询快递类型,用户查询管理员发布的快递类型。
2.3 快递区域模块
一定规模的快递公司,会有多个快递区域,每个仓库存放着不同区域的快递,比如A区域存放省内的快递,B区域存放省外的快递,所以需要建立快递区域模块,对快递的区域数据进行管理,快递区域信息包括区域名称、状态、排序值、备注、创建人、创建时间、更新人、更新时间等,快递管理员可以新增、删除、修改、条件查询快递区域,用户可以查询管理员发布的快递区域数据。
2.4 快递货架模块
快递货架模块是对快递的存放货架数据进行管理。快递货架的字段包括货架名称、所属区域、货架状态、备注、创建人、创建时间、更新人、更新时间等,快递管理员可以新增、删除、修改、条件查询快递货架,用户可以查询管理员发布的快递货架数据。
2.5 快递档案模块
快递是快递包装服务系统的核心业务,所以需要建立快递档案模块,快递的字段包括快递类型、所属货架、收件人、收件电话、收件地址、发件人、发件电话、发件地址,快递管理员可以新增、删除、修改、条件查询快递,用户可以查询管理员发布的快递数据,也可以新增快递数据。
三、界面展示
3.1 登录注册
<Form ref="usernameLoginForm" :model="form" :rules="usernameLoginFormRules" class="form">
<FormItem prop="username" class="loginInput">
<Row>
<Input v-model="form.username" size="large" clearable placeholder="登录账号" autocomplete="off">
<Icon class="iconfont icon-yonghu" slot="prefix" style="line-height:50px" />
</Input>
</Row>
</FormItem>
<FormItem prop="password">
<Input style="height:50px;line-height:50px" type="password" v-model="form.password" size="large" placeholder="请输入登录密码" password autocomplete="off">
<Icon class="iconfont icon-mima1" slot="prefix" style="line-height:50px" />
</Input>
</FormItem>
<FormItem prop="imgCode">
<Row type="flex" justify="space-between" style="align-items: center;overflow: hidden;">
<Input v-model="form.imgCode" size="large" clearable placeholder="请输入验证码" :maxlength="10" class="input-verify" />
<div class="code-image" style="position:relative;font-size:12px;">
<Spin v-if="loadingCaptcha" fix></Spin>
<img :src="captchaImg" @click="getCaptchaImg" alt="验证码加载失败" style="width:110px;cursor:pointer;display:block" />
</div>
</Row>
</FormItem>
</Form>
3.2 快递类型
@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询快递包装类型")
public Result<IPage<PackageType>>