需求分析:
后台系统中可以管理员工信息,通过新增员工来添加后台系统用户。点击 添加员工 按钮跳转到新增页面,如下:
实质就是将我们新增页面录入的员工数据插入到employee表中。需要注意的是,employee表中对username字段加入了唯一约束,因为username是员工的登录账号,必须是唯一的,employee表中的status字段已经设置了默认值1,表示状态正常,如下图所示。
实现流程:
- 页面发送ajax请求,将新增员工页面中输入的数据以json的形式提交到服务端
- 服务端Controller接收页面提交的数据并调用Service将数据进行保存
- Service调用Mapper操作数据库,保存数据
请求路径:http://localhost:8080/employee
请求方法:POST
代码开发:
在EmployeeController类中添加save方法将前端传来的json数据保存到数据库中
//新增员工
@PostMapping
public R<String> save(HttpServletRequest request, @RequestBody Employee employee){
log.info("新增员工,员工信息:{}",employee.toString());
//设置初始密码为123456,进行md5加密处理
employee.setPassword(DigestUtils.md5DigestAsHex("123456".getBytes()));
//创建和更新时间
employee.setCreateTime(LocalDateTime.now());
employee.setUpdateTime(LocalDateTime.now());
//获得当前登录用户的id
Long empId = (Long) request.getSession().getAttribute("employee");
employee.setCreateUser(empId);
employee.setUpdateUser(empId);
employeeService.save(employee);
return R.success("新增员工成功");
}
部分代码解释 :
因为需要返回给前端而且通过字符串的形式所以返回值类型是R,接受前端返回的对象,以jsion的类型进行处理所以需要使用@RequestBody 注解。
后几行代码时进行数据注入操作。
存在的问题:
当我们在新增员工时输入的账号已经存在,由于employee表中对该字段加入了唯一约束,此时程序就会抛出异常:
java.sql. SQLIntegrityConstraintViolationException: Duplicate entry 'ZHANGSAN’for key 'idx_username
此时就需要进行异常捕获来解决此遗漏,通常有两种处理方式:
1、在Controller方法中加入try、catch进行异常捕获
2、使用异常处理器进行全局异常捕获(更推荐)
在common包下,建立GlobalExceptionHandler类,并添加exceptionHandler方法用来捕获异常,并返回结果:
/**
* 全局异常处理
*/
//指定拦截哪些Controller
@ControllerAdvice(annotations = {RestController.class, Controller.class})
@ResponseBody
@Slf4j
public class GlobalExceptionHandler {
/**
* 异常处理方法
* @return
*/
@ExceptionHandler(SQLIntegrityConstraintViolationException.class)
public R<String> exceptionHandler(SQLIntegrityConstraintViolationException ex){
log.error(ex.getMessage());
if(ex.getMessage().contains("Duplicate entry")){
String[] split = ex.getMessage().split(" ");
String msg = split[2] + "已存在";
return R.error(msg);
}
return R.error("未知错误");
}
}
一些解释:
这个异常处理器是专门针对sql的bug写的,判断有没有关键字Duplicate entry,因为之前终端的报错是有这个关键字的,如果存在,那么则证明发生了SQLIntegrityConstraintViolationException,如果不存在那么属于未知错误。继续存在的逻辑,我们通过空格分开,并取出第二个位置的元素也就是人名传给前端接口,然后前端可以再界面上显示用户已存在。