Java精品项目瑞吉外卖之员工新增篇

网友投稿 294 2022-07-30


目录一. 需求分析二. 代码开发三. 编写全局异常处理

一. 需求分析

后台系统可以管理员工信息,通过新增员工来添加后台系统的用户,点击添加用户转至添加页面:

添加员工的信息需要保存至员工表【employee】中,结构如下:

其中员工状态默认设为1,表示账号在初始创建是可用的状态下的。

二. 代码开发

开发过程

开发之前,梳理一下具体的流程:

页面发送ajax请求,将员工输入的数据转换为jsON格式提交至服务器;服务端控制层接收请求数据并调用业务层将数据保存;业务层调用持久层(Mapper)将数据保存至数据库。

类似以下数据格式:

请求API:

说明值请求URL/employee请求数据JSON格式的Employee对象

代码编写:

在EmployeeController下添加如下代码:

@PostMapping

public R save(HttpServletRequest request, @RequestBody Employee employee) {

log.info("新增员工信息:{}", employee.toString());

// 设置默认密码为123456 并进行MD5加密

employee.setPassword(DigestUtils.md5DigestAsHex(CommonsConst.INIT_PASSWORD.getBytes()));

// 设置创建时间

employee.setCreateTime(LocalDateTime.now());

// 设置更新时间

employee.setUpdateTime(LocalDateTime.now());

// 用户ID设置(session中取得)

Long empId = (Long) request.getSession().getAttribute("employee");

employee.setCreateUser(empId);

employee.setUpdateUser(empId);

// 调用存储方法

employeeService.save(employee);

return R.success("添加成功");

}

测试添加数据:

数据库发现多了一天数据,说明添加成功了。

三. 编写全局异常处理

对于添加有一个问题,就是用户名已经设置了主键,若员工用户名已经存在就会报错(SQLIntegrityConstraintViolationException异常),此时我们需要捕获异常,通常捕获异常有以下两种方式:

通过try、catch进行捕获异常使用异常处理器进行全局的异常捕获

现在使用第二种方式进行异常捕获:

package com.itheima.reggie.common;

import lombok.extern.slf4j.Slf4j;

import org.springframework.stereotype.Controller;

import org.springframework.web.bind.annotation.ControllerAdvice;

import org.springframework.web.bind.annotation.ExceptionHandler;

import org.springframework.web.bind.annotation.ResponseBody;

import org.springframework.web.bind.annotation.RestController;

import java.sql.SQLIntegrityConstraintViolationException;

/**

* @author jektong

* @Date 2022/4/29

*/

@ControllerAdvice(annotations = {RestController.class, Controller.class})

@ResponseBody

@Slf4j

public class GlobalExceptionHandler {

/**

*

* @param ex

* @return

*/

@ExceptionHandler(SQLIntegrityConstraintViolationException.class)

public R exceptionHandler(SQLIntegrityConstraintViolationException ex){

log.error(ex.getMessage());

return R.error("该账号已经存在");

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:java并发编程Lock锁可重入性与公平性分析(java死锁案例)
下一篇:Java精品项目瑞吉外卖之登陆的完善与退出功能篇
相关文章

 发表评论

暂时没有评论,来抢沙发吧~