谷粒 | 02 统一返回格式

统一返回格式

1、在公共模块中创建一个子模块common_utils,提取统一返回格式功能

​ 相关依赖在父模块common已经引入,不需要再添加

2、创建一个接口(或枚举类)定义数据返回状态码

包结构也要统一

3、创建统一返回结果的实体类

结构比较固定

@Data //lombok注解,自动生成get和set方法
public class Result {
    @ApiModelProperty(value = "是否成功")
    private Boolean success;

    @ApiModelProperty(value = "状态码")
    private Integer code;

    @ApiModelProperty(value = "提示消息")
    private String message;

    @ApiModelProperty(value = "数据")
    private Map<String, Object> data = new HashMap<String, Object>();

    /*
    构造方法私有,对外只暴露指定的方法,目的是使外界无法自定义,只能统一使用规定好的格式
    */
    private Result() {}

    //对外暴露返回成功静态方法
    public static Result ok() {
        Result r = new Result();
        r.setSuccess(true);
        r.setCode(ResultCode.SUCCESS);
        r.setMessage("成功");
        return r;
    }

    //失败静态方法
    public static Result error() {
        Result r = new Result();
        r.setSuccess(false);
        r.setCode(ResultCode.ERROR);
        r.setMessage("失败");
        return r;
    }

    /*
    return this 目的是实现链式调用
    Result.ok().sucess().message() 或
    Result.error().sucess().message()
    */
    public Result success(Boolean success){
        this.setSuccess(success);
        return this;
    }

    public Result message(String message){
        this.setMessage(message);
        return this;
    }

    public Result code(Integer code){
        this.setCode(code);
        return this;
    }

    public Result data(String key, Object value){
        this.data.put(key, value);
        return this;
    }

    public Result data(Map<String, Object> map){
        this.setData(map);
        return this;
    }
}

四、使用

1、在业务service模块引入common_utils依赖

 <dependency>
            <groupId>com.birdy</groupId>
            <artifactId>common_utils</artifactId>
            <version>0.0.1-SNAPSHOT</version>
 </dependency>

2、controller控制层设置统一返回类型

@ApiOperation(value = "所有讲师列表")
    @GetMapping("findAll")
    public Result findAllTeacher(){
        List<EduTeacher> list = teacherService.list(null);
        return Result.ok().data("list",list);
    }

    @ApiOperation(value = "根据id逻辑删除讲师")
    @DeleteMapping("delete/{id}")
    public Result deleteTeacher(@PathVariable("id") String id){
        boolean flag = teacherService.removeById(id);
        if (flag) {
           return Result.ok(); //删除没有数据,只显示成功或失败
        }else {
           return Result.error();
        }

    }

posted @ 2021-01-01 22:08  至安  阅读(147)  评论(0编辑  收藏  举报