百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

一步步跑起来个 Java 前后端分离的人力资源管理系统

sinye56 2024-10-24 16:41 27 浏览 0 评论

本文适合刚学习完 Java 语言基础的人群,跟着本文可了解和运行项目,本示例是在 Windows 操作系统下演示。


本文作者:HelloGitHub-秦人

大家好!这里是 HelloGitHub 推出的《讲解开源项目》[1]系列,今天给大家带来一款基于 Java 语言的人力资源管理开源项目——微人事

微人事是一个前后端分离的人力资源管理系统,项目采用 SpringBoot + Vue 架构。该系统是管理员对员工信息的一些列的操作。首先管理员需要登入系统,可对员工信息进行增删查改操作,也可以对员工进行奖罚,工资等信息的增删查改。然后实现对部门员工信息的统计和修改。所有的操作都在系统中有日志记录。

微人事的项目地址:https://github.com/lenve/vhr

想要快速搭建一套微人事管理系统,那就跟着本文的步骤。你只需要花 10 分钟,就能拥有一个属于自己的微人事管理系统,并且可以对前后端分离的项目有一个完成的概念和感觉。下面是搭建完成的效果图:


一、技术栈

微人事这个项目采用:

1.1 后端技术栈

  • SpringBoot:SpringBoot 是基于 Spring4 进行设计,目的是为了简化 Spring 应用的初始搭建以及开发过程。该框架使用特定的方式(集成 starter,约定优于配置)来进行配置,从而使开发人员不需要再定义样板化的配置。
  • SpringSecurity:SpringSecurity 是一个强大的和高度可定制的身份验证和访问控制框架。它着重于为 Java 应用程序提供身份验证和授权。
  • MyBatis:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。
  • MySQL:MySQL 是一个轻量级关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。

1.2 前端技术栈

  • Vue:Vue 是一套构建用户界面的渐进式框架。数据驱动,组件化是 Vue 的两大核心思想。
  • ElementUI:ElementUI 时一套基于 Vue 2.0 的组件库,提供了配套设计资源。由饿了么公司前端团队开源。
  • Axios:Axios 是一个基于 Promise 的 HTTP 库,可以用在浏览器和 Node.js 中。
  • Vue-router:Vue-router 是 Vue 的路由,根据不同的路径映射到不同的视图。

二、项目结构

2.1 后端项目 hrserver 项目结构如下图:


后端项目采用 MVC 模式,使用现在流行的 SpringBoot 框架。SpringBoot 是基于 SpringMVC 衍生出来的框架。宗旨是较少配置,让开发者快速上手做项目。

目录说明:

  1. bean:数据模型目录,包括数据库模型,参数模型,业务模型。
  2. common:基础工具包目录,包括日期工具类,邮件工具类等。
  3. config:基础配置目录,包括权限认证,安全认证,菜单权限等类。
  4. controller:业务的控制器目录,包括员工信息,工资,系统公共功能等控制器。
  5. exception:自定义异常目录。公用的异常处理实现类。
  6. mapper:数据库操作层目录。包括数据接口的定义,查询 SQL 的业务实现。
  7. service:业务层目录,包括部门、员工、菜单、角色、工资等业务的业务类。
  8. HrserverApplication:SpringBoot 框架的入口类,在 IDE 中可直接运行 main 方法。
  9. resources/static:静态资源存放目录
  10. resources/templates:前台页面模板路径,包括 email 模板。
  11. resources/application.properties:环境配置文件,包括关系型数据库 mysql 连接信息,mybatis 配置文件路径,非关系型数据 redis 的连接信息,邮件服务的配置等。
  12. resources/mybatis-config.xml:mybatis 配置文件,目前包括日志带引的配置。
  13. resources/vhr.sql:MySQL 数据库脚本,(注:数据库表有外键约束,适当修改sql遇见的执行顺序 )

2.2 前端项目 vuehr 项目结构如下图:


前端项目采用 MVVM 架构,就是 MVC 架构中多了一个 ViewMode。它是 Model 和 Controller 之间的一座桥梁。

目录说明:

  1. build:Vue 项目构建配置目录,包括vue加载器的基础配置,webpack 的环境配置。
  2. config:Web 项目的环境配置目录,包括代理配置、开发环境配置、生成环境配置。
  3. node_modules:第三方依赖目录,包括项目引用的三方依赖模块。
  4. src/components:前端组件目录,包括聊天组件、员工组件、个人组件、统计组件等。
  5. src/lib:三方依赖目录,包括 SockJS,SockJS 是一个浏览器 JavaScript 库,提供类似 WebSocket 的对象。
  6. src/router:路由目录,包括项目前端路由的配置信息。
  7. src/store:全局数据商店,存放供全局使用的一些数据。
  8. src/utils:工具包路径,包括前台 API 接口和常用的工具类。
  9. src/App.vue:Vue 前端的入口组件。
  10. src/main.js:Vue 前端入口 JS 事件定义的文件。
  11. src/index.html:微人事前端首页。
  12. src/package*.json:Vue 前端项目打包的配置文件,类似于 maven 项目的 pom.xml 文件。声明了项目需要的三方依赖。

三、实战操作

3.1 准备工作

1.确保本地已安装 Java8 开发环境;

2.确保本地以安装 maven 工具;



3.确保本地以安装 Node.js;

3.2 下载项目

git clone https://github.com/lenve/vhr.git

3.3 运行项目

3.3.1 初始化数据库

数据库脚本存放的路径在:hrserver\src\main\resources\vhr.sql,我本地使用的可视化工具 Navcat。新建一个名称为 vhr 的数据库。



导入 vhr.sql 文件数据到 mysql 数据库。



3.3.2 修改后台项目的环境配置文件

修改后台项目的环境配置文件 hrserver\src\main\resources\application.properties

# MySQL 配置
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.url=jdbc:mysql://IP:3306/vhr?useUnicode=true&characterEncoding=UTF-8
spring.datasource.username=root
spring.datasource.password=root

3.3.3 IDE里运行项目

  1. 运行后端项目

a.导入后端项目到 IDEA 开发工具


b.运行后端项目

打开后台项目的入口类 HrserverApplication.java


c.项目启动成功如下图


2.运行前端项目

a.导入前端项目到 VSCode 开发工具


b.运行前端项目

c.在 VSCode 左侧导航栏,NPM SCRIPTS中直接运行 dev。


d.Ctrl+shift+Y 呼出控制台,在控制台终端依次执行如下命令:

# 安装依赖npm install
# 在 localhost:8080 启动项目npm run dev 


3.项目运行成功如下图


3.3.4 命令行运行项目

Win + R 打开 Wndows 命令行窗口

1.运行后端项目

a.切换目录到 vhr\hrserver\ 下


b.打包后台项目

 mvn clean package

c.命令行运行微人事后台项目

切换目录到 hrserver\target\,执行如下命令可启动项目

 java -jar hrserver-0.0.1-SNAPSHOT.jar

d.项目运行成功成功入下图


2.运行前端项目

a.切换目录到 vhr\vuehr\ 下


b.在命令行依次执行如下命令

# 安装依赖npm install
# 在 localhost:8080 启动项目npm run dev

c.项目运行成功成功入下图


3.3.5 项目启动成功效果

  1. 员工基本信息维护

  1. 基础信息设置

四、最后

教程至此,你应该对前后端分离的项目有了一些简单的认识。并且你也已经在本地将项目跑起来了。所谓前后端分离,其实你也可以搞定的!项目涉及的技术比较多,你可以选择感兴趣的技术去学习。后面怎么玩就看你自己了:部署到服务器正式上线、定制自己专属的功能、给项目贡献代码等,都是可以的。

本教程是针对有一定 Java 编程基础,但又不知道如果运行本项目的小伙伴。如果你是老手欢迎直接阅读项目的说明文档,获取更多更详细的资料。

References

[1] 《讲解开源项目》: https://github.com/HelloGitHub-Team/Article

[2] SpringBoot wiki: https://www.jianshu.com/p/350972a3a258

[3] Spring Security wiki: https://blog.51cto.com/favccxx/1606179

[4] MyBatis wiki: http://www.mybatis.org/mybatis-3/zh/index.html

[5] MVVM框架 wiki: https://zhuanlan.zhihu.com/p/59467370



『讲解开源项目系列』启动——让对开源项目感兴趣的人不再畏惧、让开源项目的发起者不再孤单。跟着我们的文章,你会发现编程的乐趣、使用和发现参与开源项目如此简单。欢迎加入我们,让更多人爱上开源、贡献开源~

相关推荐

程序员:JDK的安装与配置(完整版)_jdk的安装方法

对于Java程序员来说,jdk是必不陌生的一个词。但怎么安装配置jdk,对新手来说确实头疼的一件事情。我这里以jdk10为例,详细的说明讲解了jdk的安装和配置,如果有不明白的小伙伴可以评论区留言哦下...

Linux中安装jdk并配置环境变量_linux jdk安装教程及环境变量配置

一、通过连接工具登录到Linux(我这里使用的Centos7.6版本)服务器连接工具有很多我就不一一介绍了今天使用比较常用的XShell工具登录成功如下:二、上传jdk安装包到Linux服务器jdk...

麒麟系统安装JAVA JDK教程_麒麟系统配置jdk

检查检查系统是否自带java在麒麟系统桌面空白处,右键“在终端打开”,打开shell对话框输入:java–version查看是否自带java及版本如图所示,系统自带OpenJDK,要先卸载自带JDK...

学习笔记-Linux JDK - 安装&配置

前提条件#检查是否存在JDKrpm-qa|grepjava#删除现存JDKyum-yremovejava*安装OracleJDK不分系统#进入安装文件目...

Linux新手入门系列:Linux下jdk安装配置

本系列文章是把作者刚接触和学习Linux时候的实操记录分享出来,内容主要包括Linux入门的一些理论概念知识、Web程序、mysql数据库的简单安装部署,希望能够帮到一些初学者,少走一些弯路。注意:L...

测试员必备:Linux下安装JDK 1.8你必须知道的那些事

1.简介在Oracle收购Sun后,Java的一系列产品就被整合到Oracle官网中,打开官网乍眼一看也不知道去哪里下载,还得一个一个的摸索尝试,而且网上大多数都是一些Oracle收购Sun前,或者就...

Linux 下安装JDK17_linux 安装jdk1.8 yum

一、安装环境操作系统:JDK版本:17二、安装步骤第一步:下载安装包下载Linux环境下的jdk1.8,请去官网(https://www.oracle.com/java/technologies/do...

在Ubuntu系统中安装JDK 17并配置环境变量教程

在Ubuntu系统上安装JDK17并配置环境变量是Java开发环境搭建的重要步骤。JDK17是Oracle提供的长期支持版本,广泛用于开发Java应用程序。以下是详细的步骤,帮助你在Ubuntu系...

如何在 Linux 上安装 Java_linux安装java的步骤

在桌面上拥抱Java应用程序,然后在所有桌面上运行它们。--SethKenlon(作者)无论你运行的是哪种操作系统,通常都有几种安装应用程序的方法。有时你可能会在应用程序商店中找到一个应用程序...

Windows和Linux环境下的JDK安装教程

JavaDevelopmentKit(简称JDK),是Java开发的核心工具包,提供了Java应用程序的编译、运行和开发所需的各类工具和类库。它包括了JRE(JavaRuntimeEnviro...

linux安装jdk_linux安装jdk软连接

JDK是啥就不用多介绍了哈,外行的人也不会进来看我的博文。依然记得读大学那会,第一次实验课就是在机房安装jdk,编写HelloWorld程序。时光飞逝啊,一下过了十多年了,挣了不少钱,买了跑车,娶了富...

linux安装jdk,全局配置,不同用户不同jdk

jdk1.8安装包链接:https://pan.baidu.com/s/14qBrh6ZpLK04QS8ogCepwg提取码:09zs上传文件解压tar-zxvfjdk-8u152-linux-...

运维大神教你在linux下安装jdk8_linux安装jdk1.7

1.到官网下载适合自己机器的版本。楼主下载的是jdk-8u66-linux-i586.tar.gzhttp://www.oracle.com/technetwork/java/javase/downl...

window和linux安装JDK1.8_linux 安装jdk1.8.tar

Windows安装JDK1.8的步骤:步骤1:下载JDK打开浏览器,找到JDK下载页面https://d.injdk.cn/download/oraclejdk/8在页面中找到并点击“下载...

最全的linux下安装JavaJDK的教程(图文详解)不会安装你来打我?

默认已经有了linux服务器,且有root账号首先检查一下是否已经安装过java的jdk任意位置输入命令:whichjava像我这个已经安装过了,就会提示在哪个位置,你的肯定是找不到。一般我们在...

取消回复欢迎 发表评论: