Java 接口返回类

本文说明在业务系统中,如何设计返回值接口类,包括普通数据和分页数据

基类

提供基础字段,包括:success,message,code

代码

package com.tantou.maven.result;

import java.io.Serializable;

/**
 * Created by jiangweiyang on 16/11/10.
 */
public class ResultSupport implements Serializable {
    private static final long serialVersionUID = -2235152751651905167L;

    public boolean isSuccess() {
        return code == ResultCode.SuccessCode;
    }


    public String getMessage() {
        return message;
    }

    public void setMessage(String message) {
        this.message = message;
    }

    public int getCode() {
        return code;
    }

    public void setCode(int code) {
        this.code = code;
    }

    private String message;
    private int code;
}

普通数据

继承自ResultSupport,多了data字段,可以存储数组和普通对象

数据格式

数组

{
    message: null,
    code: 0,
    data: [],
    success: true
}

对象

{
    message: null,
    code: 0,
    data: {},
    success: true
}

代码

package com.tantou.maven.result;

/**
 * Created by jiangweiyang on 16/11/10.
 */
public class APIResult<T> extends ResultSupport {
    protected T data;

    public T getData() {
        return data;
    }

    public void setData(T data) {
        this.data = data;
    }

    /**
     * 接口调用失败,有错误字符串码和描述,有返回对象
     * @param code
     * @param message
     * @param data
     * @param <U>
     * @return
     */
    public static <U> APIResult<U> newFailResult(int code, String message, U data) {
        APIResult<U> apiResult = new APIResult<U>();
        apiResult.setCode(code);
        apiResult.setMessage(message);
        apiResult.setData(data);
        return apiResult;
    }

    /**
     * 接口调用失败,有错误字符串码和描述,没有返回对象
     * @param code
     * @param message
     * @param <U>
     * @return
     */
    public static <U> APIResult<U> newFailResult(int code, String message) {
        APIResult<U> apiResult = new APIResult<U>();
        apiResult.setCode(code);
        apiResult.setMessage(message);
        return apiResult;
    }


    public static <U> APIResult<U> newSuccessResult(U data){
        APIResult<U> apiResult = new APIResult<U>();
        apiResult.setData(data);
        return apiResult;
    }
}

分页数据

继承自ResultSupport,多了metadata属性,meta用于存放分页相关信息,也可以扩展成其他元数据信息,data用与存放数组信息

数据格式

{
    message: null,
    code: 0,
    data: [],
    meta: {
        pageNo: 1,
        pageSize: 2,
        totalCount: 20
    },
    success: true
}

代码

package com.tantou.maven.result;

import java.util.Collection;

/**
 * Created by jiangweiyang on 16/11/10.
 */
public class PageResult<T extends Collection> extends ResultSupport {

    protected T data;

    public T getData() {
        return data;
    }

    public void setData(T data) {
        this.data = data;
    }

    private Meta meta;

    public Meta getMeta() {
        return meta;
    }

    public void setMeta(Meta meta) {
        this.meta = meta;
    }

    public int getPageNo() {
        return meta.getPageNo();
    }

    public void setPageNo(int pageNo) {
        this.meta.setPageNo(pageNo);
    }

    public int getPageSize() {
        return this.meta.getPageSize();
    }

    public void setPageSize(int pageSize) {
        this.meta.setPageSize(pageSize);
    }

    public int getTotalCount() {
        return this.meta.getTotalCount();
    }

    public void setTotalCount(int totalCount) {
        this.meta.setTotalCount(totalCount);
    }

    public PageResult() {
        this.meta = new Meta();
    }

    public PageResult(int pageNo, int pageSize, int totalCount, T data) {
        this();
        this.setPageNo(pageNo);
        this.setPageSize(pageSize);
        this.setTotalCount(totalCount);
        this.setData(data);
    }

    /**
     * 接口调用失败,有错误字符串码和描述,有返回对象
     *
     * @param code
     * @param message
     * @param data
     * @param <U>
     * @return
     */
    public static <U extends Collection> PageResult<U> newFailResult(int code, String message, U data) {
        PageResult<U> pageResult = new PageResult<U>();
        pageResult.setCode(code);
        pageResult.setMessage(message);
        pageResult.setData(data);
        return pageResult;
    }

    /**
     * 接口调用失败,有错误字符串码和描述,没有返回对象
     *
     * @param code
     * @param message
     * @param <U>
     * @return
     */
    public static <U extends Collection> PageResult<U> newFailResult(int code, String message) {
        PageResult<U> pageResult = new PageResult<U>();
        pageResult.setCode(code);
        pageResult.setMessage(message);
        pageResult.setMeta(null);
        return pageResult;
    }

    public static <U extends Collection> PageResult<U> newSuccessResult(int pageNo, int pageSize, int totalCount, U data) {
        return new PageResult<U>(pageNo, pageSize, totalCount, data);
    }

    private class Meta {
        protected int pageNo = 1;
        protected int pageSize;
        protected int totalCount;

        public int getPageNo() {
            return pageNo;
        }

        public void setPageNo(int pageNo) {
            if (pageNo <= 0) {
                pageNo = 1;
            }
            this.pageNo = pageNo;
        }

        public int getPageSize() {
            return pageSize;
        }

        public void setPageSize(int pageSize) {
            if (pageSize < 0) {
                pageSize = 0;
            }
            this.pageSize = pageSize;
        }

        public int getTotalCount() {
            return totalCount;
        }

        public void setTotalCount(int totalCount) {
            this.totalCount = totalCount;
        }
    }
}

状态码

系统

public abstract class ResultCode {
    public static final int SuccessCode = 0;
}

业务

public static final Long DefaultAddressNotDeleteErrorCode = 10001L;//默认地址不能删除
public static final Long NotFindAddressErrorCode = 10002L;//找不到此收货地址
public static final Long NotFindUserErrorCode = 10003L;//找不到此用户
public static final Long NotMatchUserAddressErrorCode = 10004L;//用户与收货地址不匹配

应用

@RequestMapping(method = RequestMethod.GET, value = "/success")
public PageResult<List<User>> findPageResultSuccess(HttpServletRequest req) {
    List<User> users = new ArrayList<User>();
    for (int i = 0; i < 20; i++) {

        User tom = new User();
        tom.setUsername("tom" + i);
        users.add(tom);
    }
    PageResult<List<User>> result = PageResult.newSuccessResult(1, 2, users.size(), users);
    return result;
}

@RequestMapping(method = RequestMethod.GET, value = "/fail")
public PageResult<List<User>> findPageResultFail(HttpServletRequest req) {
    List<User> users = new ArrayList<User>();
    PageResult<List<User>> result = PageResult.newFailResult(1, "分页查询失败");
    return result;
}

@RequestMapping(method = RequestMethod.GET, value = "/success")
public APIResult<User> findAPIResultSuccess(HttpServletRequest req) {
    User user = new User();
    APIResult<User> result = APIResult.newSuccessResult(user);
    return result;
}

@RequestMapping(method = RequestMethod.GET, value = "/fail")
public APIResult<User> findAPIResultFail(HttpServletRequest req) {
    APIResult<User> result = APIResult.newFailResult(1, "没有找到用户");
    return result;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容