自定义通用接口返回类

一. 定义枚举类ResultCodeEnum(可以在返回类类内定义,也可以额外定义,个人喜欢分开定义)

package com.shixin.utils.enums;

import lombok.AllArgsConstructor;
import lombok.NoArgsConstructor;

/**
 * @author shixin
 * @date 2020/11/11 15:16
 */

@AllArgsConstructor
@NoArgsConstructor
public enum  ResultCodeEnum {
    /*** 通用部分 ***/
    // 通用成功请求
    SUCCESS(0, "请求成功"),
    //通用失败请求
    FAIL(1, "请求失败"),

    ;
    /**
     * 响应状态码
     */
    private Integer code;
    /**
     * 响应信息
     */
    private String message;

    public Integer getCode() {
        return code;
    }

    public String getMessage() {
        return message;
    }
}

二.通用返回类Result

package com.shixin.utils;

import com.shixin.utils.enums.ResultCodeEnum;
import lombok.Data;

/**
 * @author shixin
 * @date 2020/11/11 15:23
 */

@Data
public class Result<T> implements java.io.Serializable {

    private int code;
    private String msg;
    private T data;

    /**
     *@param
     *@desc 自定义code,message,也可以在ResultCodeEnum中提前规定
     */
    public static <T> Result<T> custom(int code, String msg, T data) {
        Result<T> result = new Result<>();
        result.setCode(code);
        result.setMsg(msg);
        result.setData(data);
        return result;
    }

    /**
     *@param
     *@desc 自定义code,message,也可以在ResultCodeEnum中提前规定
     */
    public static Result<Object> custom(int code, String msg) {
        Result<Object> result = new Result<>();
        result.setCode(code);
        result.setMsg(msg);
        return result;
    }


    public static <T> Result<T> success(String msg, T data) {
        Result<T> result = new Result<>();
        result.setCode(ResultCodeEnum.SUCCESS.getCode());
        result.setMsg(msg == null ? ResultCodeEnum.SUCCESS.getMessage() : msg);
        result.setData(data);
        return result;
    }

    public static <T> Result<T> success(T data) {
        Result<T> result = new Result<>();
        result.setCode(ResultCodeEnum.SUCCESS.getCode());
        result.setMsg(ResultCodeEnum.SUCCESS.getMessage());
        result.setData(data);
        return result;
    }

    public static Result<Object> success(String msg) {
        Result<Object> result = new Result<>();
        result.setCode(ResultCodeEnum.SUCCESS.getCode());
        result.setMsg(msg == null ? ResultCodeEnum.SUCCESS.getMessage() : msg);
        return result;
    }

    public static <T> Result<T> fail(String msg, T data) {
        Result<T> result = new Result<>();
        result.setCode(ResultCodeEnum.FAIL.getCode());
        result.setMsg(msg == null ? ResultCodeEnum.FAIL.getMessage() : msg);
        result.setData(data);
        return result;
    }

    public static Result<Object> fail(String msg) {
        Result<Object> result = new Result<>();
        result.setCode(ResultCodeEnum.FAIL.getCode());
        result.setMsg(msg == null ? ResultCodeEnum.FAIL.getMessage() : msg);
        return result;
    }

    public static Result<Throwable> error(Throwable e) {
        Result<Throwable> result = new Result<>();
        result.setCode(ResultCodeEnum.FAIL.getCode());
        result.setMsg("服务器繁忙,请稍候再试");
        result.setData(e);
        return result;
    }


}

三.测试类TestApiController

package com.shixin.api.controller;

import com.shixin.entity.Test;
import com.shixin.service.TestService;
import com.shixin.utils.Result;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

/**
 * @author shixin
 * @date 2020/11/11 15:48
 */

@RestController
public class TestApiController {

    @RequestMapping(value = "/apiget/{id}",method = RequestMethod.GET)
    public Result<Test> testResult(@PathVariable Integer id){
        Test test = new Test();
        test.setId(id);
        test.setMagicId("test");
        test.setFirstName("firstName");
        test.setLastName("lastName");
        return Result.success(test);
    }

}

四.返回结果

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值