一种好用的接口请求和响应格式规范,基于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

Git hook 开发和实践,提升自动化效率

Git hook 开发和实践,提升自动化效率

我们使用 git 进行版本控制,期间会触发很多事件,这些利用好这些事件做好自动化,能帮我提升效率。git hook 就是一个这样的工具,在特定的事件中执行特定的钩子。 ╰─➤ ls .git/hooks applypatch-msg.sample post-update.sample pre-merge-commit.sample pre-receive.sample update.sample commit-msg.sample pre-applypatch.sample pre-push.sample prepare-commit-msg.sample fsmonitor-watchman.sample pre-commit.sample pre-rebase.sample push-to-checkout.sample 设置钩子路径 git 仓库的钩子存放路径由 core.hooksPath 控制,默认是在项目的 .git/hooks。它不能使用版本控制

By brian

MacOS 安装了最新版 Docker,命令行找不到了?

它藏在 /Applications/Docker.app 中,可以使用 find 命令查看: $cd /Applications/Docker.app $find . -name "docker" ./Contents/Resources/bin/docker 将 bin 目录拼接到 PATH 环境变量即可,一般可以追加到 ~/.bashrc ~/.zshrc 中。 export PATH=/Applications/Docker.app/Contents/Resources/bin:$PATH source ~/.zshrc 使环境变量生效,执行 docker 检查版本 $ source ~/.zshrc $ docker --version Docker

By brian
飞书集成平台 x Grafana:打造监控告警系统全攻略

飞书集成平台 x Grafana:打造监控告警系统全攻略

Grafana告警内容设置 告警内容分为:告警标题、告警说明、告警详情。告警标题和告警说明用来描述告警的规则。告警详情,描述告警的规则和具体的值。 告警详情 Description 设置 1. 打印所有的标签 {{ $labels }} alertname=High CPU usage, grafana_folder=CPU alerts, instance=server1 2. 自定义格式化打印所有的标签 {{ range $k, $v := $labels -}} {{ $k }}={{ $v }} {{ end }} alertname=High CPU usage grafana_folder=CPU alerts instance=server1 3. 打印单个标签 The host {{ index $labels

By brian
沪ICP备2022013452号-1