源码获取:博客首页 "资源" 里下载!一、项目简述
功能介绍:员工管理,用户管理,部门管理,文档管理, 职位管理等等。
二、项目运行
环境配置: Jdk1.8 + Tomcat8.5 + mysql + Eclispe (IntelliJ IDEA,Eclispe,MyEclispe,Sts 都支持)
项目技术: JSP +Spring + SpringMVC + html+ css + JavaScript + JQuery + Ajax + maven等等。
【Java毕业设计项目实战篇|Java项目:企业人事管理系统(java+SSM+jsp+mysql+maven)】

文章图片

文章图片

文章图片

文章图片
后台部门管理:
/**
* 后台部门管理Controller
*/
@Controller
@RequestMapping("/admin/department")
public class DepartmentController {@Autowired
private DepartmentService departmentService;
@Autowired
private OperaterLogService operaterLogService;
/**
* 分页查询部门列表
* @param model
* @param pageBean
* @param department
* @return
*/
@RequestMapping("/list")
public String list(Model model, PageBean pageBean,Department department){
model.addAttribute("title","部门列表");
model.addAttribute("name",department.getName());
model.addAttribute("pageBean",departmentService.findList(department, pageBean));
return "/admin/department/list";
}/**
* 添加页面
* @return
*/
@RequestMapping("/add")
public String add(){
return "/admin/department/add";
}/**
* 部门添加提交处理
* @param department
* @return
*/
@RequestMapping(value = "https://www.it610.com/add",method = RequestMethod.POST)
@ResponseBody
public Result add(Department department){//用统一验证实体方法验证是否合法
CodeMsg validate = ValidateEntityUtil.validate(department);
if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
return Result.error(validate);
}if(department.getNote().length() > 50){
return Result.error(CodeMsg.DEPARTMENT_LENGTH_EXIST);
}if(departmentService.isExistName(department.getName(),0l)){
return Result.error(CodeMsg.ADMIN_DEPARTMENT_NAME_EXIST);
}if(departmentService.save(department) == null){
return Result.error(CodeMsg.ADMIN_DEPARTMENT_SAVE_ERROR);
}
operaterLogService.add("添加部门,部门名:" + department.getName());
return Result.success(true);
}/**
* 编辑页面
* @param model
* @param id
* @return
*/
@RequestMapping("/edit")
public String edit(Model model,@RequestParam(name="id",required=true)Long id){
model.addAttribute("department",departmentService.find(id));
return "/admin/department/edit";
}/**
* 编辑表单提交处理
* @param department
* @return
*/
@RequestMapping(value = "https://www.it610.com/edit",method = RequestMethod.POST)
@ResponseBody
public Result edit(Department department){
//用统一验证实体方法验证是否合法
CodeMsg validate = ValidateEntityUtil.validate(department);
if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
return Result.error(validate);
}if(department.getId() == null || department.getId().longValue() <= 0){
return Result.error(CodeMsg.ADMIN_DEPARTMENT_NO_EXIST);
}if(department.getNote().length() > 50){
return Result.error(CodeMsg.DEPARTMENT_LENGTH_EXIST);
}if(departmentService.isExistName(department.getName(),department.getId())){
return Result.error(CodeMsg.ADMIN_DEPARTMENT_NAME_EXIST);
}
//到这说明一切符合条件,进行数据库保存
Department findById = departmentService.find(department.getId());
//讲提交的用户信息指定字段复制到已存在的department对象中,该方法会覆盖新字段内容
BeanUtils.copyProperties(department, findById, "id","createTime","updateTime");
if(departmentService.save(findById) == null){
return Result.error(CodeMsg.ADMIN_DEPARTMENT_EDIT_ERROR);
}operaterLogService.add("编辑部门,部门名:" + department.getName());
return Result.success(true);
}/**
* 根据id删除
* @param id
* @return
*/
@RequestMapping(value = "https://www.it610.com/article/delete",method = RequestMethod.POST)
@ResponseBody
public Result delete(@RequestParam(name="id",required=true)Long id){
try{
departmentService.delete(id);
}catch (Exception e){
return Result.error(CodeMsg.ADMIN_DEPARTMENT_DELETE_ERROR);
}
operaterLogService.add("删除部门,部门ID:" + id);
return Result.success(true);
}
}
后台考核管理:
/**
* 后台考核管理Controller
*/
@Controller
@RequestMapping("/admin/assessment")
public class AssessmentController {@Autowired
private DepartmentService departmentService;
@Autowired
private StaffService staffService;
@Autowired
private PeranceAssmentService peranceAssmentService;
@Autowired
private AssessTargetService assessTargetService;
@Autowired
private AttendanceService attendanceService;
/**
* 分页查询员工列表
* @param model
* @param pageBean
* @param staff
* @return
*/
@RequestMapping("/list")
public String list(Model model, PageBean pageBean, Staff staff){
model.addAttribute("title","考核列表");
Staff loginedStaff = SessionUtil.getLoginedStaff();
model.addAttribute("jobNumber",staff.getJobNumber());
model.addAttribute("pageBean",staffService.findDepartmentList(staff, pageBean,loginedStaff));
return "/admin/assessment/list";
}/**
* 绩效考核页面
* @return
*/
@RequestMapping("/achieve_add")
public String add(@RequestParam("id")Long id,Model model){
Staff staff = staffService.find(id);
Long departmentId = staff.getDepartment().getId();
Department department = departmentService.find(departmentId);
List assessTargets = department.getAssessTargets();
model.addAttribute("staff",staff);
model.addAttribute("assessTargetList",assessTargets);
return "/admin/assessment/add";
}/**
* 绩效考核添加提交处理
* @param performanceAssessment
* @return
*/
@RequestMapping(value = "https://www.it610.com/achieve_add",method = RequestMethod.POST)
@ResponseBody
public Result add(PerformanceAssessment performanceAssessment,@RequestParam("assTarget")String assTarget){
//判断员工是否存在
Staff staff = performanceAssessment.getStaff();
if(staff==null){
return Result.error(CodeMsg.ADMIN_STAFF_NOT_EXIST_ERROR);
}
//年份判断
Integer year = performanceAssessment.getYear();
if(year<=0){
return Result.error(CodeMsg.ADMIN_PERFORMANCE_YEAR_ERROR);
}
//月份判断
Integer month = performanceAssessment.getMonth();
if(month<=0){
return Result.error(CodeMsg.ADMIN_PERFORMANCE_MONTH_ERROR);
}
PerformanceAssessment assessment = peranceAssmentService.findByYearAndMonthAndStaffId(year, month,staff.getId());
if(assessment!=null){
return Result.error(CodeMsg.ADMIN_PERFORMANCE_EXIST_ERROR);
}
JSONArray array = JSONObject.parseArray(assTarget);
double totalScore=0;
double weight=0;
for(int i=0;
i
后台报表管理:
/**
* 后台报表管理Controller
*/
@Controller
@RequestMapping("/admin/report_form")
public class ReportFormController {@Autowired
private DepartmentService departmentService;
@Autowired
private OperaterLogService operaterLogService;
@Autowired
private StaffService staffService;
@Autowired
private SalaryService salaryService;
/**
* 报表页面
* @return
*/
@RequestMapping("/list")
public String list(Model model,@RequestParam(name = "years",defaultValuehttps://www.it610.com/article/= "",required = false)Integer years,@RequestParam(name = "months",defaultValuehttps://www.it610.com/article/= "",required = false)Integer months){
model.addAttribute("title","报表列表");
List