员工入职管理系统|员工管理系统|基于SpringBoot+Vue的企业新员工入职系统(一)https://developer.aliyun.com/article/1423358
四,核心代码展示
package com.imnu.springboot.controller; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.imnu.springboot.entity.Department; import com.imnu.springboot.entity.Requirement; import com.imnu.springboot.entity.User; import com.imnu.springboot.exception.ServiceException; import com.imnu.springboot.mapper.RequirementMapper; import com.imnu.springboot.service.IDepartmentService; import com.imnu.springboot.service.IRequirementService; import com.imnu.springboot.service.IUserService; import com.imnu.springboot.utils.TokenUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.mail.SimpleMailMessage; import org.springframework.mail.javamail.JavaMailSender; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; import java.util.Date; import java.util.List; import java.util.Objects; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.imnu.springboot.common.Result; import com.imnu.springboot.service.IResumeService; import com.imnu.springboot.entity.Resume; import org.springframework.web.bind.annotation.RestController; /** * <p> * 前端控制器 * </p> * @author */ @RestController @RequestMapping("/resume") public class ResumeController { @Resource private IResumeService resumeService; @Resource private IRequirementService requirementService; @Resource private IUserService userService; @Resource private IDepartmentService departmentService; //从配置信息中拿去发送邮件人的信息 @Value("${spring.mail.username}") private String from; //映入发送邮件的类 @Autowired JavaMailSender javaMailSender; //新增或者更新 @PostMapping public Result save(@RequestBody Resume resume) { //获取用户名,邮箱号,部门id,岗位id String nickname = TokenUtils.getCurrentUser().getNickname(); String email = TokenUtils.getCurrentUser().getEmail(); Integer id = resume.getId(); //根据岗位id查询岗位信息 QueryWrapper<Requirement> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("id",id); Requirement one = requirementService.getOne(queryWrapper); String post = one.getPost(); Integer depId = one.getDepId(); //设置用户名,邮箱号,部门id,岗位信息 resume.setNickname(nickname); resume.setEmail(email); resume.setDepId(depId); resume.setId(null); resume.setPost(post); resume.setState("待审核"); resumeService.save(resume); return Result.success(); } //审核通过更改状态 @PostMapping("/statePass") public Result saveStatePass(@RequestBody Resume resume){ //获取申请岗位名称 String post = resume.getPost(); //获取岗位信息 QueryWrapper<Requirement> queryWrapper2 = new QueryWrapper<>(); queryWrapper2.eq("post",post); queryWrapper2.isNull("u_id"); Requirement one2 = requirementService.getOne(queryWrapper2); //根据用户名去修改用户身份 String nickname = resume.getNickname(); QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("nickname",nickname); //获取用户信息 User one = userService.getOne(queryWrapper); //修改用户身份 one.setRole("ROLE_DEP_USER"); userService.updateById(one); //拿去部门id Integer depId = resume.getDepId(); one.setDepId(depId); //修改用户部门id userService.updateById(one); //拿去岗位信息 Integer id = one2.getId(); one.setPostId(id); //修改用户岗位id userService.updateById(one); //拿去普通员工电话信息 String phone = resume.getPhone(); one.setPhone(phone); //修改用户电话信息 userService.updateById(one); //拿去普通员工地址信息 String address = resume.getAddress(); one.setAddress(address); //修改用户岗位id userService.updateById(one); //拿去普通员工简历路径 String resume1 = resume.getResume(); one.setAvatarUrl(resume1); //修改用户岗位id userService.updateById(one); //获取部门名 QueryWrapper<Department> queryWrapper1 = new QueryWrapper<>(); queryWrapper1.eq("id",depId); Department one1 = departmentService.getOne(queryWrapper1); String depName = one1.getDepName(); //发送邮件通知 String email = resume.getEmail(); //配置邮箱 SimpleMailMessage message = new SimpleMailMessage(); message.setFrom(from); message.setTo(email); Date now = new Date(); message.setSentDate(now); message.setSubject("【欧世雄企业新员工入职系统】"); message.setText(nickname+"恭喜你,你已经成功被"+depName+"录取,请尽快前来报道!"); //进行邮件发送 javaMailSender.send(message); resumeService.saveOrUpdate(resume); return Result.success(); } //删除 @DeleteMapping("/{id}") public Result del(@PathVariable Integer id){ //邮件通知该员工已被开除 QueryWrapper<Resume> queryWrapper1 = new QueryWrapper<>(); queryWrapper1.eq("id",id); Resume one1 = resumeService.getOne(queryWrapper1); String email = one1.getEmail(); String nickname = one1.getNickname(); Integer depId = one1.getDepId(); QueryWrapper<Department> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("id",depId); Department one = departmentService.getOne(queryWrapper); String depName = one.getDepName(); //通过邮件通知 SimpleMailMessage message = new SimpleMailMessage(); message.setFrom(from); message.setTo(email); Date now = new Date(); message.setSentDate(now); message.setSubject("【欧世雄企业新员工入职系统】"); message.setText("您好"+nickname+",您未通过"+depName+"的考核,很抱歉未能成为我公司的正式员工"); javaMailSender.send(message); //更改用户表信息 resumeService.removeById(id); return Result.success(); } //批量删除 @PostMapping("/del/batch") public Result deleteBatch(@RequestBody List<Integer> ids){ return Result.success(resumeService.removeByIds(ids)); } //查询全部 @GetMapping public Result findAll(){ return Result.success(resumeService.list()); } //根据id查询 @GetMapping("/{id}") public Result findOne(@PathVariable Integer id){ return Result.success(resumeService.getById(id)); } //分页查询 @GetMapping("/page") public Result findPage(@RequestParam Integer pageNum, @RequestParam Integer pageSize, @RequestParam(defaultValue = "") String nickname){ QueryWrapper<Resume> queryWrapper = new QueryWrapper<>(); queryWrapper.orderByDesc("id"); if (!"".equals(nickname)){ queryWrapper.like("nickname",nickname); } Integer depId = Objects.requireNonNull(TokenUtils.getCurrentUser()).getDepId(); queryWrapper.eq("dep_id",depId); return Result.success(resumeService.page(new Page<>(pageNum,pageSize),queryWrapper)); } }
package com.imnu.springboot.controller; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import io.swagger.models.auth.In; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; import java.util.List; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.imnu.springboot.common.Result; import com.imnu.springboot.service.IRoleService; import com.imnu.springboot.entity.Role; import org.springframework.web.bind.annotation.RestController; /** * <p> * 前端控制器 * </p> * * @author */ @RestController @RequestMapping("/role") public class RoleController { @Resource private IRoleService roleService; //新增或者更新 @PostMapping public Result save(@RequestBody Role role) { return Result.success( roleService.saveOrUpdate(role)); } //删除 @DeleteMapping("/{id}") public Result delete(@PathVariable Integer id){ return Result.success(roleService.removeById(id)); } //批量删除 @PostMapping("/del/batch") public Result deleteBatch(@RequestBody List<Integer> ids){ return Result.success(roleService.removeByIds(ids)); } //查询全部 @GetMapping public Result findAll(){ return Result.success(roleService.list()); } //根据id查询 @GetMapping("/{id}") public Result findOne(@PathVariable Integer id){ return Result.success(roleService.getById(id)); } //分页查询 @GetMapping("/page") public Result findPage(@RequestParam Integer pageNum, @RequestParam Integer pageSize, @RequestParam(defaultValue = "") String name){ QueryWrapper< Role> queryWrapper = new QueryWrapper<>(); if (!"".equals(name)){ queryWrapper.like("name",name); } return Result.success(roleService.page(new Page<>(pageNum,pageSize),queryWrapper)); } /** * 绑定角色和菜单的关系 * @param roleId 角色id * @param menuIds 菜单id数组 * @return */ @PostMapping("/roleMenu/{roleId}") public Result roleMenu(@PathVariable Integer roleId, @RequestBody List<Integer> menuIds){ roleService.setRoleMenu(roleId,menuIds); return Result.success(); } @GetMapping("/roleMenu/{roleId}") public Result getRoleMenu(@PathVariable Integer roleId){ return Result.success(roleService.getRoleMenu(roleId)); } }
package com.imnu.springboot.controller; import cn.hutool.core.collection.CollUtil; import cn.hutool.core.util.StrUtil; import cn.hutool.poi.excel.ExcelReader; import cn.hutool.poi.excel.ExcelUtil; import cn.hutool.poi.excel.ExcelWriter; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.imnu.springboot.common.Constants; import com.imnu.springboot.common.Result; import com.imnu.springboot.config.AuthAccess; import com.imnu.springboot.controller.dto.UserDto; import com.imnu.springboot.controller.dto.UserPasswordDto; import com.imnu.springboot.entity.*; import com.imnu.springboot.exception.ServiceException; import com.imnu.springboot.mapper.DepartmentMapper; import com.imnu.springboot.service.IRequirementService; import com.imnu.springboot.service.impl.UserServiceImpl; import com.imnu.springboot.service.impl.ValidationServiceImpl; import com.imnu.springboot.utils.TokenUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.mail.SimpleMailMessage; import org.springframework.mail.javamail.JavaMailSender; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.io.InputStream; import java.net.URLEncoder; import java.util.Date; import java.util.HashMap; import java.util.List; @RestController @RequestMapping("/user") public class UserController { @Autowired private UserServiceImpl userService; @Autowired private ValidationServiceImpl validationService; @Autowired private IRequirementService requirementService; //从配置信息中拿去发送邮件人的信息 @Value("${spring.mail.username}") private String from; //映入发送邮件的类 @Autowired JavaMailSender javaMailSender; //账号密码登录 @PostMapping("/loginAccount") public Result loginAccount(@RequestBody UserDto userDto){ String username = userDto.getUsername(); String password = userDto.getPassword(); if (StrUtil.isBlank(username) || StrUtil.isBlank(password)){ //检验用户名是否为空(用户名或密码为空) return Result.error(Constants.CODE_400,"参数错误"); } UserDto dto = userService.login(userDto); return Result.success(dto); } //邮箱验证码登录 @PostMapping("/loginEmail") public Result loginEmail(@RequestBody UserDto userDto){ String email = userDto.getEmail(); String code = userDto.getCode(); if (StrUtil.isBlank(email) || StrUtil.isBlank(code)){ //检验用户名是否为空(用户名或密码为空) return Result.error(Constants.CODE_400,"参数错误"); } UserDto dto = userService.loginEmail(userDto); return Result.success(dto); } //邮箱获取验证码,获取登录和重密码的验证码 @AuthAccess @GetMapping("/email/{email}/{type}") public Result sendEmailCode(@PathVariable String email,@PathVariable Integer type){ if (StrUtil.isBlank(email)){ throw new ServiceException(Constants.CODE_400,"参数错误"); } if (type==null){ throw new ServiceException(Constants.CODE_400,"参数错误"); } userService.sendEmailCode(email,type); return Result.success(); } //重置密码 @AuthAccess @PutMapping("/reset") public Result reset(@RequestBody UserPasswordDto userPasswordDto){ if (StrUtil.isBlank(userPasswordDto.getEmail()) || StrUtil.isBlank(userPasswordDto.getCode())){ throw new ServiceException(Constants.CODE_500,"参数异常"); } QueryWrapper<Validation> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("email",userPasswordDto.getEmail()); queryWrapper.eq("code",userPasswordDto.getCode()); queryWrapper.ge("time",new Date()); Validation one = validationService.getOne(queryWrapper); if (one ==null){ throw new ServiceException(Constants.CODE_500,"验证码过期,请重新获取验证码"); } //如果验证通过的话 QueryWrapper<User> queryWrapper1 = new QueryWrapper<>(); queryWrapper1.eq("email",userPasswordDto.getEmail()); User user = userService.getOne(queryWrapper1); //重置密码 user.setPassword("123"); userService.updateById(user); return Result.success(); } //修改密码 @PostMapping("/password") public Result password(@RequestBody UserPasswordDto userPasswordDto){ userPasswordDto.setPassword(userPasswordDto.getPassword()); userPasswordDto.setNewPassword(userPasswordDto.getNewPassword()); userService.updatePassword(userPasswordDto); return Result.success(); } //注册 @PostMapping("/register") public Result register(@RequestBody UserDto userDto){ String username = userDto.getUsername(); String password = userDto.getPassword(); if (StrUtil.isBlank(username) || StrUtil.isBlank(password)){ //检验前端用户输入的内容是否为空 return Result.error(Constants.CODE_400,"参数错误"); } User register = userService.register(userDto); return Result.success(register); } //查询所有数据 @GetMapping public Result findAll(){ return Result.success(userService.list()) ; } //根据用户姓名查询用户内容 @GetMapping("/username/{username}") public Result selectUsername(@PathVariable String username){ QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("username",username); User one = userService.getOne(queryWrapper); return Result.success(one); } //新增和修改 @PostMapping public Result save(@RequestBody User user){ //新增或者更新 if (user.getId()==null){ user.setPassword("123456"); } return Result.success(userService.saveOrUpdate(user)); } //根据部门id去查询岗位信息 @PostMapping("/selectPost") public Result selectPost(@RequestBody Requirement requirement){ Integer depId = requirement.getDepId(); QueryWrapper<Requirement> queryWrapper1 = new QueryWrapper<>(); queryWrapper1.eq("dep_id",depId); List<Requirement> list = requirementService.list(queryWrapper1); HashMap<String, Object> map = new HashMap<>(); map.put("list",list); return Result.success(map); } //为用户增加岗位信息并且修改岗位表中的信息 @PostMapping("/userRequirement") public Result saveUserRequirement(@RequestBody User user){ userService.saveOrUpdate(user); //获取用户id Integer id = user.getId(); //获取岗位id Integer postId = user.getPostId(); //根据岗位id去查询岗位信息 QueryWrapper<Requirement> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("id",postId); Requirement one = requirementService.getOne(queryWrapper); //修改岗位表中用户id one.setUId(id); one.setState(true); requirementService.updateById(one); return Result.success(); } @PostMapping("/noticeByEmail") public Result NoticeByEmail(@RequestBody User user){ //获取用户的用户名,密码和邮箱 String email = user.getEmail(); String password = user.getPassword(); String username = user.getUsername(); String nickname = user.getNickname(); //通过邮件通知 SimpleMailMessage message = new SimpleMailMessage(); message.setFrom(from); message.setTo(email); Date now = new Date(); message.setSentDate(now); message.setSubject("【欧世雄企业新员工入职系统】"); message.setText("您好"+nickname+",请使用以下账户密码登录公司系统:\n"+ "账号:"+username+"\n密码:"+password+"\n登录地址:http://localhost:8080/login"); javaMailSender.send(message); return Result.success(); } //删除 @DeleteMapping("/{id}") public Result delete(@PathVariable Integer id){ //更改用户表信息 userService.removeById(id); return Result.success(); } //批量删除 @PostMapping("/del/batch") public Result deleteBatch(@RequestBody List<Integer> ids){ return Result.success(userService.removeByIds(ids)); } //分页查询 @GetMapping("/page") public Result findPage(@RequestParam Integer pageNum, @RequestParam Integer pageSize, @RequestParam(defaultValue = "") String username, @RequestParam(defaultValue = "") String email, @RequestParam(defaultValue = "") String address){ IPage<User> page = new Page<>(pageNum,pageSize); QueryWrapper<User> queryWrapper = new QueryWrapper<>(); if (!"".equals(username)){ queryWrapper.like("username",username); } if (!"".equals(email)){ queryWrapper.like("email",email); } if (!"".equals(address)){ queryWrapper.like("address",address); } return Result.success( userService.page(page,queryWrapper)); } /** * 导出 */ @GetMapping("/export") public Result export (HttpServletResponse response) throws Exception { //从数据库查询到所有的数据 List<User> list = userService.list(); //在内存操作,写出到浏览器 ExcelWriter writer = ExcelUtil.getWriter(true); //自定义标题别名 writer.addHeaderAlias("username","用户名"); writer.addHeaderAlias("password","密码"); writer.addHeaderAlias("nickname","昵称"); writer.addHeaderAlias("email","邮箱"); writer.addHeaderAlias("phone","电话"); writer.addHeaderAlias("address","地址"); writer.addHeaderAlias("createTime","创建时间"); writer.addHeaderAlias("avatarUrl","头像"); //一次性的写出list内的对象到excel,使用默认样式,强制输出标题 writer.write(list,true); //设置浏览器响应的格式 response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8"); String fileName = URLEncoder.encode("用户信息","UTF-8"); response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx"); ServletOutputStream outputStream = response.getOutputStream(); writer.flush(outputStream,true); outputStream.close(); writer.close(); return Result.success(); } }
五,项目总结
在进行用户界面设计时需要充分考虑布局的合理化问题,遵循用户从上而下,自左向右浏览、操作习惯,避免常用业务功能按键排列过于分散,以造成用户鼠标移动距离过长的弊端。多做“减法”运算,将不常用的功能区块隐藏,以保持界面的简洁,使用户专注于主要业务操作流程,有利于提高平台的易用性及可用性。
1) 保持菜单简洁性及分类的准确性,避免菜单深度超过3层。
2) 未完成功能必须隐藏处理,不要置于页面内容中,以免引起误会。
3) 所有文字内容排版避免贴边显示(页面边缘),尽量保持10-20像素的 间距并在垂直方向上居中对齐;各控件元素间也保持至少 10 像素以上 的间距,并确保控件元素不紧贴于页面边沿。
4) 字符型数据保持左对齐,数值型右对齐(方便阅读对比),并根据要求, 统一显示小数位位数。
5) 页面布局设计时应避免出现横向滚动条。
6) 在页面显眼位置应该出现面包屑导航栏,让用户知道当前所在页面的 位置,并明确导航结构。
7) 信息提示窗口应位于当前页面的居中位置,并适当弱化背景层以减少 信息干扰,让用户把注意力集中在当前的信息提示窗口。一般做法是在 信息提示窗口的背面加一个半透明颜色填充的遮罩层。