前后端分离开发,后端返回前端统一json数据

现在好多公司都是前后端分离开发的项目,那么我们后端会统一给前端返回统一的返回值。一方面是后端代码接口返回值的统一,一方面是前端好理解及查看后端返回的值,那么接下来我将会写一下我在公司里所用到的统一返回值的代码。

主要运用了,枚举类,实体及返回前端方法类
枚举类我们可以随便定义我们的code和massage
代码纯属本人个人想法,不足之处还请大家多补充

Result实体类

package org.inlighting.handwritingjwt;

import lombok.Data;
import lombok.Getter;
import lombok.Setter;
import java.io.Serializable;

/**
 * description:返回前端实体类
 * date: 2020/9/23 21:19
 * @author 于嘉琪
 */
@Data
@Getter
@Setter
public class Result<T> implements Serializable {
    private String returnCode;
    private String message;
    private T data;

    public Result(String code, String msg) {
        this.returnCode = code;
        this.message = msg;
    }

    public Result(String code, String msg, T data) {
        this.returnCode = code;
        this.message = msg;
        this.data = data;
    }
}

ResultCode枚举

package org.inlighting.handwritingjwt;

/**
 * description:
 * date: 2020/9/23 21:26
 * @author yujiaqi
 */
public enum ResultCode {
    // 根据业务需要补充相应的状态码及对应的提示信息,此处作简单罗列
    OK("000000", "操作成功"),
    NOPARAMETER("E10002", "参数为空"),
    NOAUTH("E10003", "暂无接口调用权限"),
    ERROR("E10001", "系统内部异常");

    private String code;
    private String msg;

    ResultCode(String code, String msg) {
        this.code = code;
        this.msg = msg;
    }

    /**
     * 根据code值获取对应的消息
     *
     * @param code 状态码
     * @return 消息
     */
    public static String getMsgByCode(String code) {
        String msg = "";
        ResultCode[] resultCodes = values();
        for (ResultCode resultCode : resultCodes) {
            if (code.equals(resultCode.code)) {
                msg = resultCode.msg;
            }
        }
        return msg;
    }

    public String getCode() {
        return code;
    }

    public String getMsg() {
        return msg;
    }
}

ResponseEntity类

package org.inlighting.handwritingjwt;

/**
 * 返回前端方法类
 *
 * @author Yujiaqi
 * @date 2020/12/15 16:30
 */
public class ResponseEntity {
    
    public static Result success() {
        return new Result(ResultCode.OK.getCode(), ResultCode.OK.getMsg());
    }
    
    public static <T> Result success(T data) {
        return new Result(ResultCode.OK.getCode(), ResultCode.OK.getMsg(), data);
    }
    
    public static Result error() {
        return new Result(ResultCode.ERROR.getCode(), ResultCode.ERROR.getMsg());
    }
    
    public static Result error(String code) {
        return new Result(code, ResultCode.getMsgByCode(code));
    }
    
    public static Result error(String code, String msg) {
        return new Result(code, msg);
    }
    
    public static <T> Result error(String code, T data) {
        return new Result(code, ResultCode.getMsgByCode(code), data);
    }
}

main方法测试

public static void main(String[] args) {
   	Result success = ResponseEntity.success();
    System.out.println(success);
    System.out.println("---------------------");
    TestEntity testEntity = new TestEntity();
    testEntity.setId(1);
    testEntity.setName("测试名称");
    Result success1 = ResponseEntity.success(testEntity);
    System.out.println(success1);
    System.out.println("---------------------");
    Result error = ResponseEntity.error();
    System.out.println(error);
    System.out.println("---------------------");
    Result e10002 = ResponseEntity.error("E10003");
    System.out.println(e10002);
    Result e10003 = ResponseEntity.error(ResultCode.NOAUTH.getCode());
    System.out.println(e10003);
    System.out.println("---------------------");
    Result error1 = ResponseEntity.error("EEEEEE", "自定义返回码及返回信息");
    System.out.println(error1);
    Result error2 = ResponseEntity.error(ResultCode.NOAUTH.getCode(), ResultCode.NOAUTH.getMsg());
    System.out.println(error2);
    System.out.println("---------------------");
    Result error3 = ResponseEntity.error(ResultCode.NOPARAMETER.getCode(), testEntity);
    System.out.println(error3);
}

结果:
在这里插入图片描述

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: 前后端分离开发指的是前端后端开发团队之间的工作分离,前端负责界面展示和交互,后端负责数据处理和逻辑控制。 在前后端分离开发中,后端控制视图跳转的方式通常是通过在后端返回指定的状态码或数据来实现的。 例如,在使用 HTTP 协议的应用中,后端可以通过返回 HTTP 状态码来控制视图的跳转。常见的 HTTP 状态码有: - 200 OK:表示请求成功,一般用于 GET 操作。 - 201 Created:表示请求成功,且服务器已创建了新的资源。 - 204 No Content:表示请求成功,但服务器不会返回任何内容。 - 301 Moved Permanently:表示请求的资源已被永久移动到新的 URL。 - 302 Found:表示请求的资源已被临时移动到新的 URL。 后端可以在返回 HTTP 状态码的同时,在响应头中指定新的 URL,前端就可以根据这些信息来实现视图的跳转。 另一种方式是,后端在响应中返回指定的数据前端通过读取这些数据来决定视图的跳转。例如,后端可以返回一个 JSON 对象,其中 ### 回答2: 前后端分离开发是一种将前端后端开发分离的开发模式。在这种模式下,前端负责用户界面的设计和交互逻辑,后端则负责数据处理和业务逻辑。由于前后端分离,因此在前端中无法直接通过后端控制视图跳转。 但是,前后端分离开发并不意味着后端对视图跳转毫无控制能力。通过后端提供的API接口,前端可以向后端发送请求,后端在处理请求时可以根据特定条件来返回不同的视图数据,从而实现视图跳转。 具体来说,前端可以通过前端路由来控制视图的显示和跳转,当需要进行视图跳转时,前端可以向后端发送请求,请求中携带特定参数或标识,后端根据这些参数或标识进行业务处理并返回相应的视图数据前端再根据后端返回数据进行视图的展示。 例如,前端可以通过Ajax请求向后端发送一个跳转请求,后端根据请求参数判断需要跳转到哪个视图,然后返回相应的视图数据前端接收到后端返回数据后,根据数据展示相应的视图。 总的来说,虽然前后端分离开发模式下前端不能直接由后端控制视图跳转,但是通过前端后端发送请求,并根据后端返回数据进行视图展示,仍然可以实现视图的跳转效果。 ### 回答3: 在前后端分离开发中,后端通过提供一系列的API接口来处理数据和业务逻辑,而前端负责渲染页面和处理用户交互。因此,前端通过调用后端的接口来获取数据和提交请求,而不再依赖于后端的视图跳转。 对于如何通过后端控制视图跳转,可以通过以下几种方式实现: 1. 重定向:后端通过返回特定的HTTP响应状态码如302 Found,来告诉前端需要进行重定向。同时,在响应头中设置Location字段指向下一个页面的URL,前端收到响应后会自动跳转到指定的URL。 2. 返回视图URL:后端在处理请求时,可以将下一个要跳转的视图URL作为数据返回前端,在前端收到响应后,通过JavaScript或其他前端框架根据返回的URL动态进行页面跳转。 3. 前端路由:前端可以使用前端路由库如Vue Router、React Router等,在前端进行路由配置,由前端控制页面的跳转。后端只需提供一个入口页面,前端根据URL的变化来匹配对应的视图组件进行加载和渲染。 以上方式需要根据具体的开发框架和技术栈进行调整和实现。在实际开发中,可以根据项目需求和团队约定选择合适的方式来实现后端控制视图跳转,以提高开发效率和用户体验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值