全栈开发实战|人事管理系统的设计与实现(Spring Boot + Vue 3 + MyBatis)
简介: 全栈开发实战|人事管理系统的设计与实现(Spring Boot + Vue 3 + MyBatis)
01、系统设计
系统总体目标是构建某单位的人事信息管理平台,不仅满足目前的业务需要,还要满足公司未来的发展,而且具备良好的可扩展性,形成公司未来人力资源管理信息化平台。
1●系统功能需求
人力资源部门的管理员成功登录系统后,具有如下功能:
1、部门管理:主要用于描述组织的部门信息,以及部门的上下级关系。包括新建部门、修改部门、查询部门下的员工等功能。
2、岗位管理:主要用于对组织内各岗位进行管理,包括增加、修改、删除岗位,以及查询岗位下的在职人员等功能。
3、员工管理:主要用于员工基本信息录入与修改,包括员工部门、岗位、试用期及其他信息的录入。
4、试用期管理:主要对试用期员工管理,包括试用期转正、试用期延期、试用期不通过、已转正员工信息查询等功能。
5、岗位调动管理:主要对员工岗位调动管理,包括部门内岗位调动、部门间岗位调动、调动员工查询等功能。
6、员工离职管理:主要对员工离职管理,包括确定离职员工、已离职员工信息查询等功能。离职的类型包括主动辞职、辞退、退休、开除、试用期未通过。
7、报表管理:功能包括给定时间段新聘员工报表、给定时间段离职员工报表、给定时间段岗位调动员工报表、人事月报等报表查询。
2●系统模块划分
系统包括部门管理、岗位管理、员工管理、试用期管理、岗位调动管理、员工离职管理、报表管理等功能模块。具体功能模块划分如图 16.1 所示。
02、数据库设计
在 MySQL 中创建数据库 personmis,并在 personmis 中创建 6 张与系统相关的数据表:ausertable、department、post、quit、staff 和 transfer。
1●数据库概念结构设计
根据系统设计与分析,可以设计出如下数据结构:
1.管理员
包括 ID、用户名和密码。管理员的用户名和密码由数据库管理员预设,不需要注册。
2.部门
包括部门 ID、名称、类型、电话、传真、描述、上级部门以及成立日期。
3.岗位
包括岗位 ID、岗位名称、岗位类型以及编制数。
4.员工
包括员工 ID(编号)、姓名、性别、出生日期、身份证号、所在部门、所在岗位、入职日期、参加工作日期、用工形式、人员来源、政治面貌、民族、籍贯、联系电话、电子邮件、身高、血型、婚姻状况、户口所在地、最高学历、最高学位、毕业院校、所学专业、毕业日期、试用期开始日期、试用期结束日期、状态等信息。其中,编号唯一,所在部门与“2.部门 ID”关联;所在岗位与“3.岗位 ID”关联。
5.离职记录
包括 ID、员工编号、员工名称、离职类型、离职日期、记录日期。其中,ID 唯一,员工编号与“4.员工 ID”关联。
6.岗位调动记录
包括 ID、员工编号、员工名称、调动前岗位、调动后岗位、调动类型、调动日期、记录日期。其中,ID 唯一,员工编号与“4.员工 ID”关联;调动前岗位和调动后岗位与“3.岗位 ID”关联。
2●数据库逻辑结构设计
将数据库概念结构设计转换为 MySQL 数据库所支持的实际数据模型,即数据库的逻辑结构。
管理员信息表(ausertable)的设计,如表 16.1 所示。
部门信息表(department)的设计,如表 16.2 所示。
岗位信息表(post)的设计,如表 16.3 所示。
员工离职信息表(quit)的设计,如表 16.4 所示。
员工信息表(staff)的设计,如表 16.5 所示。
■ 表 16.5 员工信息表
岗位调动信息表(transfer)的设计,如表 16.6 所示。
03、后台应用的实现
1●使用 IntelliJ IDEA 构建后台应用
使用 IntelliJ IDEA 构建基于 Spring Web 和 MyBatis Framework 依赖的人事管理系统后台应用 personmis,如图 16.2 所示。
2●修改 pom.xml
修改人事管理系统 personmis 的 pom.xml 文件,添加 MySQL 连接依赖,具体代码如下:
3●配置数据源等信息
在人事管理系统 personmis 的配置文件 application.properties 中,配置端口号、数据源等信息,具体内容如下:
4●创建 CorsFilter 的 Bean 实例实现跨域访问
在 PersonmisApplication 主类中,创建 CorsFilter 的 Bean 实例实现跨域访问。PersonmisApplication 的具体代码如下:
5●管理员登录后台实现
每个功能模块的后台实现共有 5 块内容:控制器层(com.ch.personmis.controller)、业务层(com.ch.personmis.service)、数据访问层(com.ch.personmis.repository)、实体层(com.ch.personmis.entity)以及 SQL 映射文件(resources/mappers)
6●部门管理后台实现
部门管理功能模块包括增、删、改、查部门。
7●岗位管理后台实现
岗位管理功能模块包括增、删、改、查岗位。
8●员工管理与试用期管理后台实现
员工管理功能模块包括增、删、改、员工。试用期管理包括条件查询试用期员工、试用期转正、延期等操作。
9●岗位调动管理后台实现
岗位调动管理功能模块包括录入岗位调动信息、多条件查询岗位调动信息。
10●员工离职管理后台实现
员工离职管理功能模块包括录入员工离职信息、查询及条件查询员工离职信息。
11●报表管理后台实现
报表管理功能模块包括新聘员工报表、离职员工报表以及岗位调动报表的查询。
04、前端项目的实现
1●使用 Vue CLI 搭建前端项目
使用 Vue CLI 搭建基于 Router 和 Vuex 功能的前端项目 personmis-vue。搭建成功后,使用 VSCode 打开 personmis-vue 目录即可进行前端项目的实现。
2●安装 axios
在前端界面组件中,我们通过 axios 模块向后端提交 Ajax 异步请求。所以需要打开 VSCode 的 Terminal 终端命令行窗口,执行 npm install --save axios 命令安装 axios 模块。
3●设置反向代理
成功安装 axios 模块后,首先在 personmis-vue 的入口文件 main.js 中,将 axios 挂载到 vue 实例上,示例代码如下:
其次,在 personmis-vue 根目录下,创建 Vue 的配置文件 vue.config.js,设置反向代理支持,示例代码如下:
4●配置页面路由
在 src/router/index.js 文件中,配置页面路由。跳转登录界面的路由不需要登录权限验证,需要加上 meta:{auth:true}数据,以便在路由钩子函数中判断。路由配置内容具体如下:
5●安装 Element Plus
Element Plus 是一套为开发者、设计师和产品经理准备的基于 Vue 3.0 的桌面端组件库。我们使用 Element Plus 辅助开发人事管理系统的前端界面组件。所以,首先需要打开 VSCode 的 Terminal 终端命令行窗口,执行 npm install element-plus --save 命令安装 Element Plus 组件库。然后,在 src 目录下,创建 plugins 目录,并在该目录下新建 Element Plus 的配置文件 element.js,配置内容如下:
最后,在 personmis-vue 的入口文件 main.js 中,将 Element Plus 组件库安装到 vue 实例上,示例代码如下:
上述操作流程,如图 16.3 所示。
6●管理员登录界面实现
前端项目首页路由默认跳转到登录界面。在 views 目录中,创建登录界面组件 Login.vue。Login.vue 的运行效果,如图 16.4 所示。
7●界面导航组件实现
登录成功后,进入部门管理界面。在所有管理界面中,都将引入界面导航组件,如图 16.5 所示。
8●部门管理界面实现
部门管理界面有两个界面组件,一个是新增部门界面组件,一个是管理部门界面组件。在 views 目录中,创建新增部门界面组件 AddDepartment.vue,运行效果如图 16.6 所示;创建管理部门界面组件 Department.vue,运行效果如图 16.7 所示。
在图 16.6 所示的新增部门界面中,部门名称和部门类型是必需输入项,上级部门是从数据库查询出来,供管理员选择。
在图 16.7 所示的部门管理界面中,可以根据部门名称和部门类型进行查询,并可对部门进行编辑、详情以及删除(不能删除有数据关联的部门)操作。
9●岗位管理界面实现
岗位管理界面有两个界面组件,一个是新增岗位界面组件,一个是管理岗位界面组件。在 views 目录中,创建新增岗位界面组件 AddPost.vue,运行效果如图 16.8 所示;创建管理岗位界面组件 Post.vue,运行效果如图 16.9 所示。
在图 16.8 所示的新增岗位界面中,岗位名称和岗位类型是必需输入项。
在图 16.9 所示的岗位管理界面中,可以根据岗位名称和岗位类型进行查询,并可对岗位进行编辑、详情以及删除(不能删除有数据关联的岗位)操作。
10●员工管理界面实现
员工管理界面有两个界面组件,一个是新增员工界面组件,一个是管理员工界面组件。在 views 目录中,创建新增员工界面组件 AddStaff.vue,运行效果如图 16.10 所示;创建管理员工界面组件 Staff.vue,运行效果如图 16.11 所示。
在图 16.11 所示的员工管理界面中,可以根据员工名称和部门名称进行查询,并可对员工进行编辑、详情以及删除(不能删除有数据关联的员工)操作。
11●试用期管理界面实现
在 views 目录中,创建试用期管理界面组件 PeroidOp.vue,运行效果如图 16.12 所示。在试用期管理界面中,可以对正常状态的试用期人员进行转正、延期、不录用等操作。同时,也可以根据多个条件查询处于试用期的员工。
12●岗位调动管理界面实现
岗位调动管理界面有两个界面组件,一个是录入岗位调动界面组件,一个是查询调动员工界面组件。在 views 目录中,创建录入岗位调动界面组件 AddTransferStaff.vue,运行效果如图 16.13 所示;创建查询调动员工界面组件 TransferStaff.vue,运行效果如图 16.14 所示。
在图 16.13 所示的录入岗位调动界面中,可以根据员工编号自动带入员工姓名和之前岗位。
13●员工离职管理界面实现
员工离职管理界面有两个界面组件,一个是录入离职员工界面组件,一个是查询已离职员工界面组件。在 views 目录中,创建录入离职员工界面组件 AddQuit.vue,运行效果如图 16.15 所示;创建查询已离职员工界面组件 Quit.vue,运行效果如图 16.16 所示。
在图 16.15 所示的录入离职员工界面中,可以根据员工编号自动带入员工姓名。
14●报表管理界面实现
报表管理界面有三个界面组件,一个是新聘员工报表界面组件,一个是离职员工报表界面组件,一个是岗位调动报表界面组件。在 views 目录中,创建新聘员工报表界面组件 NewStaffReport.vue,运行效果如图 16.17 所示;创建离职员工报表界面组件 QuitStaffReport.vue,运行效果如图 16.18 所示;创建岗位调动报表界面组件 TransferStaffReport.vue,运行效果如图 16.19 所示。
05、测试运行
首先,运行后台应用 personmis 的主类 PersonmisApplication,启动 personmis,如图 16.20 所示。
其次,在打开 personmis-vue 的 VSCode 的 Terminal 终端命令行窗口中,执行 npm run serve 命令启动前端项目 personmis-vue。
最后,可通过 http://localhost:8080/测试运行。
版权声明: 本文为 InfoQ 作者【TiAmo】的原创文章。
原文链接:【http://xie.infoq.cn/article/3f93d129c82eee20b164769bf】。文章转载请联系作者。
评论