Skip to main content

自建一个Resful风格的接口自助服务,方便API自动化测试工具的开发与调试!

Project description

A Api Server

一、概述

A api server,是一个 Resful 风格的简易 API 服务,提供了对用户账号进行增删改查(CRUD)功能的接口服务,包含了接口的签名校验机制,方便 API 自动化测试工具的开发与调试!

1. 本地启动服务

  • (1)命令行启动
pip install A-Api-Server
a_api_server 自定义端口号(默认5000)
  • (2)clone 源码启动
pip install gunicorn flask
cd a_api_server
python api_server.py 自定义端口号(默认5000)

(注意:兼容 Python2 和 Python3)

2. 服务端启动服务,推荐使用 gunicorn

cd a_api_server
gunicorn api_server:app -p api_server.pid -b 0.0.0.0:5000 -w 4 -D

服务端关闭服务的命令如下:
kill -HUP `cat api_server.pid`
kill `cat api_server.pid`

3. 启动后访问地址

http://your.ip:5000

二、接口文档

1. API V1 接口说明

  • 接口基准地址:http://your.ip:5000/
  • 使用 HTTP Status Code 标识状态
  • 数据返回格式统一使用 JSON
  • API V1 认证统一使用 Token 认证
  • 需要授权的 API ,必须在请求头中使用device_sn字段提供设备序列号和 token 字段提供访问令牌
  • 全局请求头
参数名 参数类型 参数说明 备注
Content-Type String 内容类型 application/json
device_sn String 设备序列号 唯一设备标识符
token String 访问令牌 拥有 token 的设备才有访问权

1.1. 支持的请求方法

  • GET(SELECT):从服务器取出资源(一项或多项)。
  • POST(CREATE):在服务器新建一个资源。
  • PUT(UPDATE):在服务器更新资源(客户端提供改变后的完整资源)。
  • PATCH(UPDATE):在服务器更新资源(客户端提供改变的属性)。
  • DELETE(DELETE):从服务器删除资源。
  • HEAD:获取资源的元数据。
  • OPTIONS:获取信息,关于资源的哪些属性是客户端可以改变的。

1.2. 通用返回状态说明

状态码 含义 说明
200 OK 请求成功
201 CREATED 创建成功
204 DELETED 删除成功
400 BAD REQUEST 请求的地址不存在或者包含不支持的参数
401 UNAUTHORIZED 未授权
403 FORBIDDEN 被禁止访问
404 NOT FOUND 请求的资源不存在
422 Unprocesable entity [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误
500 INTERNAL SERVER ERROR 内部错误

2. 具体接口说明

2.1. 获取令牌

  • 请求路径:/api/get-token
  • 请求方法:post
  • 请求头
参数名 参数类型 参数说明 备注
User-Agent String 用户代理
device_sn String 设备序列号
os_platform String 系统平台
app_version String 应用版本
  • 请求参数
参数名 参数类型 参数说明 备注
sign String 加密签名 根据请求头和密钥加密生成
  • 响应参数
参数名 参数类型 参数说明 备注
success Boolean 是否成功
token String 访问令牌 长度 16 位
  • 成功返回
状态码:200
响应体:
{
    'success': true,
    'token': "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1aW"
}
  • 失败返回
状态码:403
响应体:
{
    'success': false,
    'msg': "Authorization failed!"
}
  • 签名生成算法
def get_sign(*args):
    SECRECT_KEY = 'YouMi'
	content = ''.join(args).encode('ascii')
	sign_key = SECRECT_KEY.encode('ascii')
	sign = hmac.new(sign_key, content, hashlib.sha1).hexdigest()
	return sign

sign = get_sign(user_agent, device_sn, os_platform, app_version)

2.2. 新建用户

  • 请求路径:/api/users/:id
  • 请求方法:post
  • 请求参数
参数名 参数类型 参数说明 备注
id Int 用户 ID
name String 用户名
password String 密码
  • 响应参数
参数名 参数类型 参数说明 备注
success Boolean 是否成功
msg String 说明信息
  • 成功返回
状态码:201
响应体:
{
    'success': true,
    'msg': "user created successfully."
}
  • 失败返回
状态码:422
响应体:
{
    'success': false,
    'msg': "user already existed."
}

2.3. 根据 ID 查询用户信息

  • 请求路径:/api/users/:id
  • 请求方法:get
  • 响应参数
参数名 参数类型 参数说明 备注
success Boolean 是否成功
name String 用户名
password String 密码
  • 成功返回
状态码:200
响应体:
{
    'success': true,
    'data': {
        'name': 'admin',
        'password': '123456'
    }
}
  • 失败返回
状态码:404
响应体:
{
    'success': fasle,
    'data': {}
}

2.4. 更新用户信息

  • 请求路径:/api/users/:id
  • 请求方法:put
  • 请求参数
参数名 参数类型 参数说明 备注
id Int 用户 ID
name String 用户名
password String 密码
  • 响应参数
参数名 参数类型 参数说明 备注
success Boolean 是否成功
data Dict 用户信息
  • 成功返回
状态码:200
响应体:
{
    'success': true,
    'data': {
        'name': 'admin',
        'password': '123456'
    }
}
  • 失败返回
状态码:404
响应体:
{
    'success': fasle,
    'data': {}
}

2.5. 删除用户信息

  • 请求路径:/api/users/:id
  • 请求方法:delete
  • 请求参数
参数名 参数类型 参数说明 备注
id Int 用户 ID
  • 响应参数
参数名 参数类型 参数说明 备注
success Boolean 是否成功
data Dict 用户信息
  • 成功返回
状态码:200
响应体:
{
    'success': true,
    'data': {
        'name': 'admin',
        'password': '123456'
    }
}
  • 失败返回
状态码:404
响应体:
{
    'success': fasle,
    'data': {}
}

2.6. 用户数据列表

  • 请求路径:/api/users
  • 请求方法:get
  • 响应参数
参数名 参数类型 参数说明 备注
success Boolean 是否成功
count Int 用户总数
items Array 用户数据集合
  • 成功返回
状态码:200
响应体:
{
    'success': true,
    'count': 3,
    'items': [
        {'name': 'admin1', 'password': '123456'},
        {'name': 'admin2', 'password': '123456'},
        {'name': 'admin3', 'password': '123456'}
    ]
}

2.7. 清空用户数据

  • 请求路径:/api/reset-all
  • 请求方法:get
  • 响应参数
参数名 参数类型 参数说明 备注
success Boolean 是否成功
  • 成功返回
状态码:200
响应体:
{
    'success': true
}

三、自动化发布:一键打 Tag 并上传至 PYPI

每次在 ** about **.py 更新版本号后,运行以下命令,实现自动化更新打包上传至 PYPI ,同时根据其版本号自动打 Tag 并推送到仓库:

python3 setup.py pypi

注意:上传前需提前在 twine 工具中配置自己的 Pypi 的账号信息!!!

四、CHANGELOG

v1.0.0
1、实现对用户账号进行增删改查功能的 API 服务,包含了接口的签名校验机制;
2、完善了 API 使用文档;
3、添加了自动化打包脚本;

五、致谢

A-Api-Server 工具的产生和打包,主要参考了开源项目 HttpRunner,受益多多,感谢!

LICENSE

MIT License

Copyright (c) 2019 Devin https://zhangchuzhao.site
Copyright (c) 2017 Toby Qin

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

A_Api_Server-1.1.7.tar.gz (8.2 kB view hashes)

Uploaded Source

Built Distribution

A_Api_Server-1.1.7-py2.py3-none-any.whl (7.9 kB view hashes)

Uploaded Python 2 Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page