🍅 作者主页:Selina .a
🍅 简介:Java领域优质创作者🏆、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行交流合作。
主要内容:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。
🍅文末获取源码联系🍅
目录
课题的提出
伴随着我国社会的发展,人民生活质量日益提高。于是对电力员工安全施工培训进行规范而严格是十分有必要的,所以许许多多的信息管理系统应运而生。此时单靠人力应对这些事务就显得有些力不从心了。所以本论文将设计一套电力员工安全施工培训管理系统,帮助企业进行培训班、学习课程、企业文化、培训考试、企业公告等繁琐又重复的工作,提高工作效率的同时,也减轻了管理者的压力。
本论文的主要内容包括:
第一,研究分析当下主流的web技术,结合企业日常管理方式,进行电力员工安全施工培训管理系统的数据库设计,设计电力员工安全施工培训管理系统功能,并对每个模块进行说明。
第二,陈列说明该系统实现所采用的架构、系统搭建采用的服务器、系统开发环境和使用的工具,以及系统后台采用的数据库。
最后,对系统进行全面测试,主要包括功能测试、查询性能测试、安全性能测试。
分析系统存在的不足以及将来改进的方向。
数据库设计
概念模型是对现实中的问题出现的事物的进行描述,ER图是由实体线以及关联构成的图,E-R图可以明确地叙述系统中涵盖的实体线相互关系。
培训班信息实体图如图4-2所示:
学习课程实体图如图4-3所示:
员工信息实体图如图4-4所示:
系统功能设计
网站首页页面主要包括首页、培训班、学习课程、企业文化、交流论坛、培训考试、企业公告、留言反馈、后台管理等内容,并根据需要进行详细操作;如图5-1所示:
注册时将进行密码校验,若密码不一致将不能注册,以此来防止员工输入错误密码,影响体验,下面截图是员工注册成功页面,如图5-2所示。
员工将在此界面进行身份验证和登录,该页面将在前台提交数据给后台之前对表单中的用户名和密码进行格式校验,比如输入的验证信息不能为空,并给予相应的提示信息,下面截图是员工登录成功页面,如图5-3所示。
员工点击培训班,在培训班页面的搜索栏输入培训班名称,进行查询,也可以查看培训班编号、培训班名称、培训班分类、图片、报名状态等内容,并进行在线报名或者评论等操作;如图5-4所示。
员工点击留言反馈,在留言反馈页面查看留言内容、留言图片、回复内容、回复图片等内容,进行提交等操作。如图5-5所示。
员工点击个人中心,在个人中心页面可以修改个人信息、密码修改,还可以对我的发布、考试记录、错题本、我的收藏进行详细操作,如图5-6所示。
管理员进行登录,进入系统前在登录页面根据要求填写用户名和密码等信息,点击登录操作,如图5-7所示。
管理员登录系统后,可以对首页、个人中心、员工管理、培训班分类管理、培训班管理、在线报名管理、学习课程管理、企业文化管理、留言反馈、交流论坛、培训考试管理、试题管理、系统管理、考试管理等进行相应的操作管理,如图5-8所示。
管理员点击员工管理,在员工管理页面输入员工工号、姓名、性别、头像、年龄、电话号码等信息,然后进行查询、新增或删除员工信息等操作,如图5-9所示。
管理员点击培训班管理,在培训班管理页面输入培训班编号、培训班名称、培训班分类、图片、报名状态等信息,然后进行查询、新增或删除培训班等操作,如图5-10所示。
管理员点击在线报名管理,在在线报名管理页面输入报名编号、培训班名称、培训班分类、报名时间、员工工号、姓名、审核回复、审核状态、审核等信息,然后进行查询或删除在线报名等操作,如图5-11所示。
管理员点击学习课程管理,在学习课程管理页面对课程编号、课程名称、图片、视频、课程资料等信息,然后进行查询、新增或删除学习课程等操作,如图5-12所示。
管理员点击留言反馈,在留言反馈页面对用户名、留言内容、留言图片、回复内容、回复图片等信息,然后进行查询或删除留言反馈信息等操作,如图5-13所示。
员工登录系统后,可以对首页、个人中心、在线报名管理等进行相应的操作管理,如图5-14所示。
员工点击在线报名管理,在在线报名管理页面输入报名编号、培训班名称、培训班分类、报名时间、员工工号、姓名、审核回复、审核状态、审核等信息,然后进行查询在线报名等操作,如图5-15所示。
关键代码
package com.controller;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import com.annotation.IgnoreAuth;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.entity.TokenEntity;
import com.entity.UserEntity;
import com.service.TokenService;
import com.service.UserService;
import com.utils.CommonUtil;
import com.utils.MPUtil;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.ValidatorUtils;
/**
* 登录相关
*/
@RequestMapping("users")
@RestController
public class UserController{
@Autowired
private UserService userService;
@Autowired
private TokenService tokenService;
/**
* 登录
*/
@IgnoreAuth
@PostMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
if(user==null || !user.getPassword().equals(password)) {
return R.error("账号或密码不正确");
}
String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
return R.ok().put("token", token);
}
/**
* 注册
*/
@IgnoreAuth
@PostMapping(value = "/register")
public R register(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);
if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}
/**
* 退出
*/
@GetMapping(value = "logout")
public R logout(HttpServletRequest request) {
request.getSession().invalidate();
return R.ok("退出成功");
}
/**
* 密码重置
*/
@IgnoreAuth
@RequestMapping(value = "/resetPass")
public R resetPass(String username, HttpServletRequest request){
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
if(user==null) {
return R.error("账号不存在");
}
user.setPassword("123456");
userService.update(user,null);
return R.ok("密码已重置为:123456");
}
/**
* 列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,UserEntity user){
EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/list")
public R list( UserEntity user){
EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
ew.allEq(MPUtil.allEQMapPre( user, "user"));
return R.ok().put("data", userService.selectListView(ew));
}
/**
* 信息
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") String id){
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 获取用户的session用户信息
*/
@RequestMapping("/session")
public R getCurrUser(HttpServletRequest request){
Long id = (Long)request.getSession().getAttribute("userId");
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 保存
*/
@PostMapping("/save")
public R save(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);
if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);
UserEntity u = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername()));
if(u!=null && u.getId()!=user.getId() && u.getUsername().equals(user.getUsername())) {
return R.error("用户名已存在。");
}
userService.updateById(user);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
userService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
}
专栏推荐
Spring Boot+Vue+CSS+JavaScript+HTML等技术项目专栏推荐
推荐项目
基于Node.js+Vue+MySQL的小型企业工资管理系统
基于Spring Boot+Android+MySQL的记录生活管理系统
源码获取
大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻