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

A-Api-Server的Python项目详细描述


A Api Server

一、概述

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

1. 本地启动服务

  • (1)pipy 安装启动
pip install A-Api-Server
a_api_server 自定义端口号(默认5000)
  • (2)clone 源码启动
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-TypeString内容类型application/json
device_snString设备序列号唯一设备标识符
tokenString访问令牌拥有 token 的设备才有访问权

1.1. 支持的请求方法

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

1.2. 通用返回状态说明

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

2. 具体接口说明

2.1. 获取令牌

  • 请求路径:/api/get-token
  • 请求方法:post
  • 请求头
参数名参数类型参数说明备注
User-AgentString用户代理
device_snString设备序列号
os_platformString系统平台
app_versionString应用版本
  • 请求参数
参数名参数类型参数说明备注
signString加密签名根据请求头和密钥加密生成
  • 响应参数
参数名参数类型参数说明备注
successBoolean是否成功
tokenString访问令牌长度 16 位
  • 成功返回
状态码:200
响应体:
{
    'success': true,
    'token': "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1aW"
}
  • 失败返回
状态码:403
响应体:
{
    'success': false,
    'msg': "Authorization failed!"
}
  • 签名生成算法
defget_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()returnsignsign=get_sign(user_agent,device_sn,os_platform,app_version)

2.2. 新建用户

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

2.3. 根据 ID 查询用户信息

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

2.4. 更新用户信息

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

2.5. 删除用户信息

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

2.6. 用户数据列表

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

2.7. 清空用户数据

  • 请求路径:/api/reset-all
  • 请求方法:get
  • 响应参数
参数名参数类型参数说明备注
successBoolean是否成功
  • 成功返回
状态码: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.

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
在Eclipse中使用多个调用在一行上打印java   javajackson序列化问题。只有同一实体的第一个对象可以很好地序列化   Java中Deflate函数的等价充气   使用customlitview的java Android actionbar搜索   java“<T>T get()”是什么意思?(它有用吗?)   目标c使用CommonCrypto使用AES256加密,使用OpenSSL或Java解密   java在运行时更新资源文件   fileinputstream在java中访问并将数据写入现有文件   带集群的java Android Mapbox我希望每个功能都有不同的标记图像   java JDK8>JDK10:PKIX路径生成失败:SunCertPathBuilderException:找不到请求目标的有效证书路径   java使用Hk2生成具有指定构造函数参数的实例   为什么这个系统。出来Java中的println()打印到控制台?   java目录和文件名连接不起作用   使用mockito和通配符绘图的java