一种好用的接口请求和响应格式规范,基于Google Json Style

一种好用的接口请求和响应格式规范,基于Google Json Style
Photo by Ferenc Almasi / Unsplash

简述

  1. 基于较为流行的谷歌 json 风格 google json style
    1. 英文 https://google.github.io/styleguide/jsoncstyleguide.xml
    2. 中文 https://github.com/darcyliu/google-styleguide/blob/master/JSONStyleGuide.md
  2. 所有字段驼峰命名,接口使用:get post
    1. get 获取数据
    2. post 更新数据
  3. post:请求 body 数据使用 application/json, 不使用 FormData;
  4. 响应成功,仅返回 data;响应错误,仅返回 error。如果data和error同时出现,则error对象优先。
  5. HTTP_STATUS 始终200, 如果非 200,则说明出现错误,提示“服务器异常”。

POST 请求:

{
    "method": "thread.review.list 可简化",
    "params": {
        "id": 100,
        "type": 1
    }
}

接口响应:

正确响应
  1. 列表响应 items
{
    "apiVersion": "2.0",
    "method": "thread.review.list",
    "data": {
        "tableHeader": {
            "id": "ID",
            "name": "标题"
        },
        "items": [
            {
                "id": 10021,
                "name": "第一个帖子"
            }
        ],
        "pagination": {
            "pageIndex": 50,
            "totalPages": 10,
            "itemsPerPage": 50,
            "totalItems": 495,
            "currentItemCount": 45
        }
    }
}

  1. 详细数据响应 item
{
    "apiVersion": "2.0",
    "method": "thread.review.detail",
    "data": {
        "item": {
            "id": 10031,
            "name": "第一个帖子"
        }
    }
}

发生错误

{
    "apiVersion": "2.0",
    "method": "thread.review.list",
    "error": {
        "code": 400,
        "message": "数据异常",
        "errors": [
            {
                "domain": "Calendar",
                "reason": "ResourceNotFoundException",
                "message": "File Not Found"
            }
        ]
    }
}

错误处理

  1. 响应存在 error 则说明发生错误,error 优先级高于 data
  2. error.message 始终 toast 提示
  3. 特殊逻辑处理根据 error.code 进行判断
  4. HTTP_STATUS 始终200, 如果非 200,则说明出现错误,提示“服务器异常”
  5. 调用接口成功响应,提示文案由前端处理
  6. 业务中的特殊逻辑,在 data 返回处理
特殊 error.code 列表

见仁见智

error.code error.message 逻辑 备注
10000100 登录失效,请重新登录 跳转到登录页
10000101 - 刷新页面
10000102 - 跳转到指定404页面

Read more

golang proto api 校验国际化 protovalidate

golang proto api 校验国际化 protovalidate

众所周知,protobuf 原型文件扩展很多功能,比如生成 http 接口层代码,顺势就有了生成接口参数校验代码的需求。 早期可以使用https://github.com/bufbuild/protoc-gen-validate 来实现,通过生成特定的 go 代码的方式来实现校验。 github 中也提到目前趋于稳定,不会有更多新特性的支持,推荐大家使用新的版本 protovalidate,https://github.com/bufbuild/protovalidate 。该版本是protoc-gen-validate 的“精神继承者”。它不需要任何代码生成并支持自定义约束。 现在我们尝试新版本,并且增加国际化支持。 go get github.com/bufbuild/protovalidate-go import "github.com/bufbuild/protovalidate-go" syntax = "proto3"; package

By brian
git clone 复制一个整个仓库并推送到新地址

git clone 复制一个整个仓库并推送到新地址

要使用 git clone --bare 复制一个新的仓库并推送到远程仓库,可以按照以下步骤操作: 1. 克隆一个裸仓库 首先,使用 git clone --bare 命令克隆源仓库。假设源仓库的 URL 是 https://github.com/user/source-repo.git,你可以执行以下命令: bash复制 git clone --bare https://github.com/user/source-repo.git 这将创建一个新的裸仓库(没有工作区),通常会创建一个名为 source-repo.git 的目录。 2. 进入裸仓库目录 进入刚刚克隆的裸仓库目录: bash复制 cd source-repo.git 3. 添加新的远程仓库 接下来,

By brian
搜索引擎技巧不用多,学会 3 个加速 100% 找到目标

搜索引擎技巧不用多,学会 3 个加速 100% 找到目标

在搜索时使用英文关键词,提高结果质量。尽量使用 google.com 以下搜索引擎技巧在 google.com 进行测试,效果都很好,前三个非常常用且强烈推荐。 使用精确搜索 * 建议: 使用双引号 "" 搜索完全匹配的短语,避免无关结果。 * 示例: * "Java NullPointerException" fix * 场景: 找到错误信息的精确解决方案。 利用站内搜索 * 建议: 使用 site: 限制搜索范围到特定网站。 * 示例: * site:stackoverflow.com "TypeError: undefined is not a function" * 场景: 搜索 Stack Overflow、官方文档或技术博客的特定内容。 一些关键词 * 建议:

By brian
沪ICP备2022013452号-1