当前位置:   article > 正文

python框架sanic_Python Web框架Sanic框架初识

sanic web 框架读音

Sanic 既是一个Python web 服务器,又是一个web框架,它为速度而生。Sanic只支持Python 3.5及其以上版本,允许我们使用

async/await

语法来使我们的代码非阻塞且快速。

通过pip安装Sanic

pip3 install sanic

Sanic 使用

uvloop

ujson

来提高性能。但是,目前Windows上不支持

uvloop

,只能使用

asnycio

原生的事件循环。不过不影响你在Windows上使用Sanic,不用担心这个问题,如果想深入了解 它就去看看Sanic的源码中

server.py

worker.py

。其实,就是在代码中

import uvloop

时处理了

ImportError

异常。

如果你不喜欢这两个包,可以通过设置环境变量

SANIC_NO_UVLOOP=true

SANIC_NO_UJSON=true

来禁止安装它们。

$ export SANIC_NO_UVLOOP=true

$ export SANIC_NO_UJSON=true

$ pip3 install sanic

Sanic简单示例

下面是一个最简单的Sanic web 应用,写入文件

app-simple.py

# file: app-simple.py

from sanic import Sanic

from sanic.response import json

app = Sanic()

@app.route('/')

async def test(request):

msg = {'message': 'Welcom to 猿人学Python'}

return json(msg, ensure_ascii=False)

if __name__ == '__main__':

app.run(host='127.0.0.1', port=8888)

在命令行下运行这个web app:

python3 app-simple.py

运行成功可以看到如下输出:

[2019-03-21 21:29:57 +0800] [10766] [INFO] Goin' Fast @ http://127.0.0.1:8888

[2019-03-21 21:29:57 +0800] [10766] [INFO] Starting worker [10766]

用浏览器或

curl

访问

http://127.0.0.1:8888

,就可以看到输出结果。下面是命令

curl -i http://127.0.0.1:8888

的结果:

HTTP/1.1 200 OK

Connection: keep-alive

Keep-Alive: 5

Content-Length: 39

Content-Type: application/json

{"message":"Welcom to 猿人学Python"}

Sanic示例详解

(1)首先,从

sanic

包导入

Sanic

类,这个是一个Sanic web app (web应用)的入口类。根据我们app的响应数据类型从

sanic.response

导入相应的响应函数,比如本例中的

json()

(2)接着,生成一个

Sanic

的实例

app

(3)

app

实例有两个最常用的方法

app.route()

app.run()

app.route()

是一个装饰器,通过它定义我们app的访问路径(路由),比如本例中的

test()

函数就是用来响应根路径:

/

通过

@app.route()

可以定义整个web app的各种路由。

(4)最后,通过

app.run()

方法来运行app,开启一个web服务。

使用Sanic开发web应用的过程就是这么简单。如果开发复杂的网站,就是不断重复第三步,并使用

blueprint

来使代码结构更清晰。后面,我们将一一介绍使用Sanic开发网站的方方面面。你准备好了吗,让我们一起开启Sanic开发之旅吧!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/136956
推荐阅读
相关标签
  

闽ICP备14008679号