【瑞吉外卖】学习笔记-day2:(一)新增员工

需求分析:

后台系统中可以管理员工信息,通过新增员工来添加后台系统用户。点击 添加员工 按钮跳转到新增页面,如下:

 实质就是将我们新增页面录入的员工数据插入到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,如果不存在那么属于未知错误。继续存在的逻辑,我们通过空格分开,并取出第二个位置的元素也就是人名传给前端接口,然后前端可以再界面上显示用户已存在。

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值