封装统一返回结果

前言

目前,前后端分离的项目越来越多。如果项目采用前后端分离的方式去开发的话,后端只提供API接口,前端通过Ajax去调用接口。那么前后端需要提前定义好数据格式,为了减少沟通成本,需要封装一个统一返回结果的。

响应类

@Getter
//@ApiModel(value = "全局统一返回结果")
public class Result {
    //    @ApiModelProperty(value = "是否成功")
    private Boolean success;

    //    @ApiModelProperty(value = "返回码")
    private Integer code;

    //    @ApiModelProperty(value = "返回消息")
    private String message;

    //    @ApiModelProperty(value = "返回数据")
    private Object data;

    private Result() {

    }

    private Result(ResultCode resultCode) {
        this.success = resultCode.getSuccess();
        this.code = resultCode.getCode();
        this.message = resultCode.getMessage();
    }

    public static Result ok() {
        return new Result(ResultCode.SUCCESS);
    }

    public static Result error() {
        return new Result(ResultCode.UNKNOWN_ERROR);
    }

    public static Result error(ResultCode resultCode) {
        return new Result(resultCode);
    }

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

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

    public Result data(Object obj) {
        this.data = obj;
        return this;
    }
}

响应码

@Getter
public enum ResultCode {
    SUCCESS(true, 2000, "成功"),
    UNKNOWN_ERROR(false, 4000, "未知错误"),

	BAD_CREDENTIALS(false, 3001, "用户名或密码输入错误!请重新输入!"),
    CREDENTIALS_EXPIRED(false, 3002, "密码过期,请联系管理员!"),
    ACCOUNT_EXPIRED(false, 3003, "账户过期,请联系管理员!"),
    ACCOUNT_LOCKED(false, 3004, "账户被锁定,请联系管理员!"),
    ACCOUNT_DISABLED(false, 3005, "账户被禁用,请联系管理员!"),
    EXCEED_MAX_SESSION(false, 3006, "您的账号已在别的地方登录,不允许重复登录!"),
    
	SMS_SEND_ERROR(false, 5000, "短信发送失败");

    private Boolean success;
    private Integer code;
    private String message;

    ResultCode(Boolean success, Integer code, String message) {
        this.success = success;
        this.code = code;
        this.message = message;
    }
}

依赖包

		<dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
        </dependency>

        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
        </dependency>

使用

@GetMapping("code/sms")
    public Result smsCode(HttpServletRequest request, @RequestParam String mobile) {
        // 1.生成手机验证码
        String code = RandomStringUtils.randomNumeric(4);
        // 2.存放到session中
        request.getSession().setAttribute(Constant.SMS_CODE, code);
        // 3.发送手机验证码
        smsService.sendSms(mobile, code);
        // Result.ok() 默认成功,message = "成功"
        // Result.ok().data(这个可以传入对象) 默认成功,message = "成功",带响应数据
        // Result.error() 默认失败,message = "未知错误"
        // Result.error().message("短信发送失败") 自定义提示信息
        // Result.error(ResultCode.SMS_SEND_ERROR) 可传入自定义枚举类
        return Result.ok().message("短信发送成功");
    }
Java中,我们经常需要对方法的返回结果进行封装,以便在调用端能够方便地处理返回结果。这样做可以提高代码的可读性和可维护性。一种常见的做法是使用Java的泛型机制,定义一个统一返回结果类,如下所示: ``` public class Result<T> { private int code; private String message; private T data; // 省略构造器和getter/setter方法 // 静态工厂方法,表示成功的返回结果 public static <T> Result<T> success(T data) { Result<T> result = new Result<>(); result.setCode(200); result.setMessage("success"); result.setData(data); return result; } // 静态工厂方法,表示失败的返回结果 public static <T> Result<T> failure(int code, String message) { Result<T> result = new Result<>(); result.setCode(code); result.setMessage(message); return result; } } ``` 在这个类中,我们定义了三个字段:code、message和data,分别表示返回结果的状态码、状态消息和返回数据。我们还定义了两个静态工厂方法,分别表示成功的返回结果和失败的返回结果。 使用这个类,我们可以在方法中返回一个Result类型的对象,表示方法的执行结果: ``` public Result<User> getUserById(int id) { User user = userDao.getUserById(id); if (user != null) { return Result.success(user); } else { return Result.failure(404, "User not found"); } } ``` 在调用端,我们可以通过判断返回结果的状态码来判断方法是否执行成功,并通过获取返回结果的数据来获取方法执行的结果: ``` Result<User> result = userService.getUserById(id); if (result.getCode() == 200) { User user = result.getData(); // 处理成功的情况 } else { String message = result.getMessage(); // 处理失败的情况 } ``` 这样,我们就可以通过一个统一返回结果类来封装方法的返回结果,提高代码的可读性和可维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值