使用 Pyramid 和 Cornice 构建和描述可扩展的 RESTful Web 服务。python
Python 是一种高级的、面向对象的编程语言,它以其简单的语法而闻名。它一直是构建 RESTful API 的顶级编程语言之一。linux
Pyramid 是一个 Python Web 框架,旨在随着应用的扩展而扩展:这可让简单的应用很简单,也能够增加为大型、复杂的应用。此外,Pyramid 为 PyPI (Python 软件包索引)提供了强大的支持。Cornice 为使用 Pyramid 构建和描述 RESTful Web 服务提供了助力。git
本文将使用 Web 服务的例子来获取名人名言,来展现如何使用这些工具。github
首先为你的应用建立一个虚拟环境,并建立一个文件来保存代码:web
$ mkdir tutorial
$ cd tutorial
$ touch main.py
$ python3 -m venv env
$ source env/bin/activate
(env) $ pip3 install cornice twisted
复制代码
使用如下命令导入这些模块:数据库
from pyramid.config import Configurator
from cornice import Service
复制代码
将引用服务定义为 Service
对象:编程
QUOTES = Service(name='quotes',
path='/',
description='Get quotes')
复制代码
到目前为止,这仅支持获取名言。用 QUOTES.get
装饰函数。这是将逻辑绑定到 REST 服务的方法:json
@QUOTES.get()
def get_quote(request):
return {
'William Shakespeare': {
'quote': ['Love all, trust a few, do wrong to none',
'Some are born great, some achieve greatness, and some have greatness thrust upon them.']
},
'Linus': {
'quote': ['Talk is cheap. Show me the code.']
}
}
复制代码
请注意,与其余框架不一样,装饰器不会更改 get_quote
函数。若是导入此模块,你仍然能够按期调用该函数并检查结果。api
在为 Pyramid RESTful 服务编写单元测试时,这颇有用。bash
最后,使用 scan
查找全部修饰的函数并将其添加到配置中:
with Configurator() as config:
config.include("cornice")
config.scan()
application = config.make_wsgi_app()
复制代码
默认扫描当前模块。若是要扫描软件包中的全部模块,你也能够提供软件包的名称。
我使用 Twisted 的 WSGI 服务器运行该应用,可是若是须要,你能够使用任何其余 WSGI 服务器,例如 Gunicorn 或 uWSGI。
(env)$ python -m twisted web --wsgi=main.application
复制代码
默认状况下,Twisted 的 WSGI 服务器运行在端口 8080 上。你能够使用 HTTPie 测试该服务:
(env) $ pip install httpie
...
(env) $ http GET <http://localhost:8080/>
HTTP/1.1 200 OK
Content-Length: 220
Content-Type: application/json
Date: Mon, 02 Dec 2019 16:49:27 GMT
Server: TwistedWeb/19.10.0
X-Content-Type-Options: nosniff
{
"Linus": {
"quote": [
"Talk is cheap. Show me the code."
]
},
"William Shakespeare": {
"quote": [
"Love all,trust a few,do wrong to none",
"Some are born great, some achieve greatness, and some greatness thrust upon them."
]
}
}
复制代码
Pyramid 并非最受欢迎的框架,但它已在 PyPI 等一些引人注目的项目中使用。我喜欢 Pyramid,由于它是认真对待单元测试的框架之一:由于装饰器不会修改函数而且没有线程局部变量,因此能够直接从单元测试中调用函数。例如,须要访问数据库的函数将从经过 request.config
传递的 request.config
对象中获取它。这容许单元测试人员将模拟(或真实)数据库对象放入请求中,而不用仔细设置全局变量、线程局部变量或其余特定于框架的东西。
若是你正在寻找一个通过测试的库来构建你接下来的 API,请尝试使用 Pyramid。你不会失望的。
via: opensource.com/article/20/…
做者:Moshe Zadka 选题:lujun9972 译者:geekpi 校对:wxy