許多小伙伴在看完小編的json api接口的使用后,會發(fā)現(xiàn)大公司提供的json都有一定的格式。而且仿佛有一定的規(guī)律。接下來這篇文章,小編將帶你了解為什么要對json接口進行封裝,以及了解json封裝數(shù)據(jù)的方法(以java為例)。
案例介紹
還記得快遞一百api接口返回的JSON嗎?我們請求這個鏈接的時候:
鏈接:?http://www.kuaidi100.com/query?type=ems&postid=1111111111111
?
返回如下結(jié)果:
{
"message": "ok",
"nu": "1111111111111",
"ischeck": "1",
"com": "ems",
"status": "200",
"condition": "F00",
"state": "3",
"data": [
{
"time": "2021-05-26 09:45:08",
"context": "查無結(jié)果",
"ftime": "2021-05-26 09:45:08"
}
]
}
在看了其他api文檔后我們發(fā)現(xiàn),很多api返回的json都有一定的特點。比如都有status,都有message等等。接下來小編就來帶你了解,一個json應該有哪些數(shù)據(jù)吧?
分析
一個json應該有哪些數(shù)據(jù),應該由前端和后端進行討論后得出,小編列出一些選項供各位小伙伴參考:
status:響應狀態(tài),一個json應該告訴前端返回狀態(tài),方便前端進行處理,比如出現(xiàn)404的時候應該通過前端跳轉(zhuǎn)到404頁面,響應信息就是用在這里。
message:響應信息,這個信息一般用來報錯,如果沒錯就返回ok,有出現(xiàn)錯誤一般后端會把錯誤填寫入這個字段中,比如權(quán)限不足這樣的輔助提示,前端也可以將這個信息展示給用戶。
data:用來存放數(shù)據(jù),一般會以數(shù)組方式來存放數(shù)據(jù),以對象數(shù)組存放的數(shù)據(jù)通常用來存放列表數(shù)據(jù)
page:存放分頁的頁數(shù),有做數(shù)據(jù)分頁的情況下,一般會返回一個page值。前端可以針對這個page值確定當前分頁的頁數(shù)
有些json還會根據(jù)前端的需求定義一些返回值,比如標題,url,時間等,json數(shù)據(jù)的定制具體還是由前后端交流后得出。
后端如何封裝JSON數(shù)據(jù)
以下是小編開發(fā)過的一個web項目的json封裝代碼,各位小伙伴可以用作參考:
設置狀態(tài)碼:
public enum ResultType {
SUCCESS("200", "操作成功"),
FAIL("400", "操作失敗"),
UNAUTHORIZED("401", "權(quán)限不足"),
NOT_FOUND("404", "接口不存在"),
INTERNAL_SERVER_ERROR("500", "服務器內(nèi)部錯誤"),
AGAIN_LOGIN("600", "請重新登錄");
private String code;
private String name;
ResultType(String code, String name) {
this.code = code;
this.name = name;
}
public String getCode() {
return code;
}
public String getName() {
return name;
}
}
json封裝:
import java.io.Serializable;
// 請求返回結(jié)果對象
public class Result<T> implements Serializable{
//返回狀態(tài)編碼
private String statusCode = ResultType.SUCCESS.getCode();
//返回提示信息
private String message = ResultType.SUCCESS.getName();
//返回結(jié)果
private T data = null;
//是否成功
private Boolean success = true;
//獲取狀態(tài)編碼
public String getStatusCode() {
return statusCode;
}
//設置狀態(tài)編碼@param statusCode
public void setStatusCode(String statusCode) {
this.statusCode = statusCode;
}
//獲取提示信息
public String getMessage() {
return message;
}
// 設置提示信息 @param message
public void setMessage(String message) {
this.message = message;
}
//獲取返回結(jié)果@return
public T getData() {
return data;
}
//設置返回結(jié)果@param data
public void setData(T data) {
this.data = data;
}
public Boolean isSuccess() {
return success;
}
public void setSuccess(Boolean success) {
this.success = success;
}
public void addError() {
this.addError("");
}
public void addError(String message) {
this.success = false;
this.message = message;
this.statusCode = ResultType.INTERNAL_SERVER_ERROR.getCode();
if(this.message == null || "".equals(this.message)){
this.message = ResultType.INTERNAL_SERVER_ERROR.getName();
}
}
public void success() {
this.success("");
}
public void success(String message) {
this.success = true;
this.message = message;
this.statusCode = ResultType.SUCCESS.getCode();
if(this.message == null || "".equals(this.message)){
this.message = ResultType.SUCCESS.getName();
}
}
public void fail() {
this.fail("");
}
public void fail(String message) {
this.success = false;
this.message = message;
this.statusCode = ResultType.FAIL.getCode();
if(this.message == null || "".equals(this.message)){
this.message = ResultType.FAIL.getName();
}
}
public void unauthorized() {
this.unauthorized("");
}
public void unauthorized(String message) {
this.success = false;
this.message = message;
this.statusCode = ResultType.UNAUTHORIZED.getCode();
if(this.message == null || "".equals(this.message)){
this.message = ResultType.UNAUTHORIZED.getName();
}
}
public void notFound() {
this.notFound("");
}
public void notFound(String message) {
this.success = false;
this.message = message;
this.statusCode = ResultType.NOT_FOUND.getCode();
if(this.message == null || "".equals(this.message)){
this.message = ResultType.NOT_FOUND.getName();
}
}
public void againLogin() {
this.againLogin("");
}
public void againLogin(String message) {
this.success = false;
this.message = message;
this.statusCode = ResultType.AGAIN_LOGIN.getCode();
if(this.message == null || "".equals(this.message)){
this.message = ResultType.AGAIN_LOGIN.getName();
}
}
}
小結(jié)
以上就是json封裝數(shù)據(jù)的全部內(nèi)容。更多json知識可以參考json教程。