Java项目实战跟练day4——springboot + mybatis plus开发

Java项目实战跟练day4——springboot + mybatis plus开发

一、员工管理部分

新增员工

程序执行流程:
1.页面发送ajax请求,将新增员工页面中输入的数据以json的形式提交到服务端;
2.服务端Controller接收页面提交的数据并调用Service将数据进行保存;
3.Service调用Mapper操作数据库,保存数据。
①前端请求的路径和方式
在这里插入图片描述
在这里插入图片描述
②EmployeeController.java

    /*
    新增员工
     */
    @PostMapping
    public R<String> addEmployee(HttpServletRequest request,@RequestBody Employee employee){
        //设置初始密码123456,需要进行md5加密处理
        String password = DigestUtils.md5DigestAsHex("123456".getBytes());
        employee.setPassword(password);
        log.info("新增员工,员工信息为:{}",employee.toString());
        employee.setCreateTime(LocalDateTime.now());
        employee.setUpdateTime(LocalDateTime.now());
        //获取当前登录用户信息
        Long empId = (Long)request.getSession().getAttribute("employee");
        employee.setCreateUser(empId);
        employee.setUpdateUser(empId);
        employeeService.save(employee);//IService中的现成方法
        return R.success("新增用户成功");
    }

③数据库表结构设计中,指定用户账号(username)为唯一约束,设置用户状态默认值为1(即正常状态)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注意:由于username是唯一约束,当新增员工的账号在数据库中已经存在时,会报错:SQLIntegrityConstraintViolationException
解决方法:建立一个全局异常类GlobalExceptionHandler.java,处理项目所有的异常问题。

@ControllerAdvice(annotations ={RestController.class, Controller.class} )
@ResponseBody
@Slf4j
//拦截加了RestController注解的controller文件
public class GlobalExceptionHandler {
    /*
    异常处理方法
     */
    @ExceptionHandler(SQLIntegrityConstraintViolationException.class)
    public R<String> exceptionHandler(SQLIntegrityConstraintViolationException ex){
        log.info(ex.getMessage());
        if(ex.getMessage().contains("Duplicate entry")){
            String[] s = ex.getMessage().split(" ");
            String msg = s[2]+"已存在";
            return R.error(msg);
        }
        return R.error("未知错误");
    }
}

目前项目结构为:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值