计算机毕业设计 | vue+springboot人事管理系统 OA后台管理(附源码)

1,项目概述

人事管理系统功能包括人事通讯,员工信息,人事考评、奖惩,培训管理,薪资管理,统计分析和系统管理六大模块。对应人事工作基本流程:新员工入职档案建立,调动,辞职,员工信息的查询及工资管理等方面。

系统管理可以根据不同的角色分配菜单权限设置,不同的用户授予不同角色,对人事结构,单位结构进行整体调配设置。在线聊天可以实现操作员之间讯息的及时通讯。

前后端分离是指将前端和后端从之前的全部由后端负责中分离开来,不再共用一个Server,前端作为一个独立Serve存在。前后端通过接口使用HTTP协议交互,本项目使用vu实体属性outer做前端路由处理。页面跳转不在由后端处理,前后端只是数据的交互,前后端分离的好处在于降低了前后端的耦合性。当面对不同的硬件场景时,需要构建不同的界面,前后端分离之后,只需要扩展前端项目即可,不需要修改后端服务。

在动态权限处理方面,使用安全框架Spring Security,基于RBAC(Role-Based Access Control )角色的访问控制模型,由该模型主要由鉴权和授权构成,鉴权基于Servlet中Filter原理处理,授权由系统管理员操作。RBAC 的主要思想是:权限是和角色相关的,而用户则被分配相应的角色作为其成员,这样就大大简化了权限的管理。

2,技术栈

后端技术

技术说明官网
SpringBootWeb应用开发框架https://spring.io/projects/spring-boot
SpringSecurity认证和授权框架https://spring.io/projects/spring-security
MyBatisORM框架http://www.mybatis.org/mybatis-3/zh/index.html
MyBatisGenerator数据层代码生成器http://www.mybatis.org/generator/index.html
Druid数据库连接池https://github.com/alibaba/druid
JWTJWT登录支持https://github.com/jwtk/jjwt
LombokJava语言增强库https://github.com/rzwitserloot/lombok
PageHelperMyBatis物理分页插件http://git.oschina.net/free/Mybatis_PageHelper
Swagger-UIAPI文档生成工具https://github.com/swagger-api/swagger-ui

前端技术

技术说明官网
Vue前端框架https://vuejs.org/
Vue-router路由框架https://router.vuejs.org/
Vuex全局状态管理框架https://vuex.vuejs.org/
Element前端UI框架https://element.eleme.io
Axios前端HTTP框架https://github.com/axios/axios
v-charts基于Echarts的图表框架📣 有源码 获取源码

3,项目界面展示

用户登录访问后由Spring Security 的 WebSecurity Configurer Adapter类实现认证和授权校验,登录成功后跳转主页,之后的每一次访问都会通过校验用户,角色,基于Ant格式的URL权限的匹配。

在这里插入图片描述

3 公共模块展示

3.1 主页

主页由日志和系统公告构成,逻辑处理上默认加载最新的操作日志及公告信息,数据展示通过Spring定时任务方式。服务端定时执行SQL。以排序和截取方式获取最新入库数据,动态更新数据。
在这里插入图片描述

3.2 在线聊天

在线聊天实现点对点的在线通讯。前端基于全双工通信WebSocket实现,WebSocket由HTTP建立连接,由TCP进行会话,Web服务器与客户端之间建立起WebSocket协议的连接,之后的协议都依靠专用协议进行,通信过程中可以互发送JSON,XML,HTML或图片等任意格式的数据,由于是建立在HTTP基础的协议上,即发起方仍是客户端,一旦确立WebSocket通信连接,不论服务器还是客户端,任意一方都可以直接向对方发送报文。在处理逻辑上,由键值对构建消息对象。

后端基于Spring 框架提供的 WebSocket 的 STOMP 支持,STOMP 是一个简单的可互操作的协议,通常被用于通过中间服务器在客户端之间进行异步消息传递。

在这里插入图片描述

3.3 员工资料

3.3.1 基本资料

实现对员工基本资料的增删改查,实现员工基本资料表Excel导入导出,多条件搜索,添加员工由数据库自动生成工号,其他信息为必填项。修改根据id进行数据更新。

3.3.2 高级资料

高级资料主要实现查询功能,由以下三部分信息构成:

  1. 培训资料:培训日期,培训内容
  2. 考评资料:考评日期,考评内容,考评结果
  3. 工资信息:账套名称,基本工资

在这里插入图片描述

3.4 人事管理

3.4.1 员工奖惩

人事管理主要用于对员工奖惩,培训,考评,调动信息的管理。员工奖惩主要对员工奖惩模块的增删改查的实现。在UI设计上使用穿梭框和tab标签,逻辑处理上员工实体和奖惩信息是一对多的关系,即对同一员工在相同或者不同时间都可以添加多个奖惩,奖惩管理页面显示有奖惩信息的全部员工,可以查看奖惩详情。

在这里插入图片描述
在这里插入图片描述

3.4.2 员工培训

员工培训模块主要是对员工培训业务的增删改查的实现。员工培训由添加培训和培训管理两个子模块构成。在UI设计上加了进度条。逻辑处理上是一对一的关系,即同一员工在一个时间段只能参加一个培训,培训完成删除当前培训后可以添加新的培训,支持批量添加培训,培训进度修改。

在这里插入图片描述
在这里插入图片描述

3.4.3 员工好评

员工好评模块即对员工评价业务的增删改查的实现。UI设计上结合评分条步骤条,支持批量添加评价。逻辑处理上是一对一的关系。

在这里插入图片描述
在这里插入图片描述

3.4.4 员工调动

员工调动模块即对员工调用的增删改查的实现。UI设计上由table内嵌table构成,逻辑处理上是一对多的关系。
在这里插入图片描述
在这里插入图片描述

3.5 工资管理

3.5.1 工资账套管理

实现对员工工资账套管理,员工账套设置,工资表管理,查询一系列对员工工资管理的功能。工资账套管理主要对员工奖金,基本工资,提成等各项的增刪改查。设置当前套账信息。

3.5.2 员工账套设置

员工讨账设置主要根据公司账套查看相应的员工的工资信息,并实现员工套账的其增删功能。

3.5.3 工资表管理

工资表管理集中对员工工资,进行搜索查看的功能。添加筛选过滤功能,可以根据不同的职称部门进行表内筛选,工资套账详情查看。

在这里插入图片描述
在这里插入图片描述

3.6 统计管理

统计管理主要对员工资料的动态分析统计,包括员工积分统计,人事信息统计,人事记录统计。在设计方面结合图表处理 VeCharts,由服务端对数据进行了整合,由VeCharts展示。代码方面,结合java 8 的 Stream API及数据库端聚合函数实现。数据动态展示基于Spring定时任务。

3.6.1 员工积分统计

根据工号查找员工的积分情况。以条形图显示当前有积分员工的积分分布情况。积分分值由员工奖惩产生。

在这里插入图片描述

3.6.2 人事信息统计

人事信息统计主要对员工人数信息进行的分析统计,饼图的方式展示。以高校、职称、职位、党派、民族、学历、部门为维度的人员分布图,用于人事统计。
在这里插入图片描述

3.6.3 人事记录统计

人事记录统计主要对员工离职信息的统计,以部门、职称、职位为维度,对员工离职率、离职工龄、离职年龄进行分析。以柱状图结合折线图的方式统计。

在这里插入图片描述

3.7 系统管理

3.7.1 基础信息设置

系统管理主要对系统,管理员等一些操作,包括基础设置,系统管理,操作员管理,授权处理。基础信息设置主要对部门,职位,职称,奖惩规则和权限组的设置增删查改功能管理,实现部门树,权限树预览,职称等级设置。奖惩描述自定义及使用模糊提示等。

部门管理主要以多叉树的方式实现部门信息展示。及添加删除部门的操作。展示的实现由在Server端基于递归SQL的方式遍历部门树。删除操作当存在子部门,不能删除父部门。只能从叶子部门进行删除操作。添加不受限制。

员工职位管理即对企业职位的管理。由职位展示查询及自定义职位添加删除更改职位状态构成,员工奖惩管理主要用于自定义员工奖惩。由添加奖惩类型、分值、描述及删除修改编辑构成。自定义奖惩描述可以使用以有描述,也可以自己定义,员工职称管理于职位管理类似。由职称展示查询及自定义职称添加删除,更改职称状态构成。不同在于职称有对应等级。添加时需要选择职称等级。

用户权限管理由权限树预览、角色添加、角色权限设置构成。权限树在数据处理上以二叉树的结构展示。因为只有两级菜单,对于不同角色通过权限树的设置,赋予不同菜单权限。权限树预览是基于VeCharts树形图表的展示。在UI设计上,以折叠面板和Tree树型组件方式实现。

在这里插入图片描述
在这里插入图片描述

3.7.2 系统管理

系统管理主要由公告管理和公告编辑构成。公告编辑主要结合VueQuillEditor富文本第三方扩展实现,有标题和具体公告内容构成,公告管理包括公告修改、公告预览、公告删除。可以动态修改所有公告信息并实现预览。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.7.3 操作日志管理

操作日志管理主要展示登录用户对系统的操作信息。记录具体人事操作,便于以后的信息检索,功能上实现由日志类型,日期间隔的日志查询。

在这里插入图片描述

3.8 操作员管理

操作员管理在UI设计上使用卡片组件,弹性布局处理。功能包括基本信息展示,刪改功能,具体由管理员角色权限的设置,是否启用的修改,删除管理员操作构成。在权限修改上以相互赋予的方式实现,即登录用户不能自己给自己赋值。只能通过其他用户赋予权限。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

说书客啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值