Sanic-请求与响应

Sanic是一个类似Flask的Python 3.5+ Web服务器,它的写入速度非常快。除了Flask之外,Sanic还支持异步请求处理程序。这意味着你可以使用Python 3.5中新的闪亮的异步/等待语法,使你的代码非阻塞和快速。

前言:Sanic最低支持Python 3.5,如果需要学习Sanic,请先下载版本不低于3.5的Python包

请求数据

当一个端点收到一个HTTP请求时,路由功能被传递到一个request对象。以下变量可以作为request对象的属性访问:

  • json:JSON数据
@app.route("/post_data",methods=["POST"])
async def post_data(request):
    # 将打印传递过来的JSON数据
    print(request.json)
    return text("it is ok!")
  • args:查询字符串变量。查询字符串是类似于URL的部分?name=laozhang&age=20。如果URL被解析,那么args字典将如下所示:{"name":["laozhang"],"age":[20]}
  • raw_args:在许多情况下,我们需要获取压缩程度低的字典中的url参数。对于之前的URL?name=laozhang&age=20raw_args字典将如下所示:{"name":"laozhang","age":20}
  • file:文件对象字典,具有名称,正文和类型的文件列表
@app.route("/post_file_data",methods=["POST"])
async def post_file_data(request):
    info = request.files.get("file")
    print(info.name)
    print(info.type)
    print(info.body)

    return text("it is ok!")
  • form:表单数据,form字典将如下所示:{"name":["laozhang"]}
@app.route("/post_form_data",methods=["POST"])
async def post_form_data(request):
    name = request.form.get("name")
    return text("it is ok!")
  • body:原始数据。无论内容类型如何,该属性都允许检索请求的原始数据。byte类型
  • headers:获取请求表头的不区分大小写的字典。dict类型
  • ip:IP地址,str类型
  • port:端口,str类型
  • socket:请求者的IP地址和端口,(IP地址,端口)。tuple类型
  • app:对处理请求的Sanic应用程序对象的引用。
@appr.route("/get_app_info")
async def get_app_info(request):
    print(request.app.config)
    return text("it is ok!")
  • url:请求的完整URL,如:http://localhost:5000/get_app_info
  • scheme:获取与请求关联的URL方案:httphttps
  • host:获取与请求关联的主机
  • path:获取请求的路径,如:/get_app_info
  • query_string:获取查询的字符串,如:name=zhangsan或者为一个空白字符串
  • uri_template:获取匹配路由处理程序的模板,如:/get/
  • token:授权标头的值

get与getlist

当我们访问一个GET请求,并传入相关参数时,如下的请求:

@app.route("/get_info")
async def get_info(request):
    print(request.args.get("name"))
    print(request.args.getlist("name")
    return text("it is ok!")

当我们传入一个namelaozhang时,在上面有提到,args字典将会是{"name":["laozhang"],所以,访问上面的路由,将会打印如下结果:

laozhang
["laozhang"]

响应

使用sanic.response模块中的函数来创建响应

  • 纯文本
from sanic.response import text

@app.route("/text")
async def get_text(request):
    return text("it is text response!")
  • HTML
from sanic.response import html

@app.route("/html")
async def get_html(request):
    return html("

it is html!

"
)
  • JSON
from sanic.response import json

@app.route("/json")
async def get_json(request):
    return json({"name":"laozhang"})
  • FILE
from sanic.response import file

@app.route("/file")
async def get_file(request):
    return await file("/xx/aa/abc.png")

切记,不能少了await关键字

  • STREAM
from sanic.response import stream

@app.route("/stream")
async def get_stream(request):
    async def stream_fn(response):
        response.write("abc")
        response.write("def")
    return stream(stream_fn,content_type="text/plain")
  • 文件流:针对大文件,上面文件与流的组合
from sanic.response import file_stream

@app.route("/file_stream")
async def get_file_stream(request):
    return await file_stream("/xx/aa/abc.png")

切记,不能少了await关键字

  • 重定向
from sanic.response import redirect

@app.route("/redirect")
async def get_redirect(request):
    return redirect("/json")
  • RAW:未编码的body响应
from sanic.response import raw

@app.route("/raw")
async def get_raw(request):
    return raw(b"it is raw data")

访问此接口后,将会立即下载一个名为raw的文件,里面包含内容it is raw data

  • 修改请求头和状态值:如果需要修改请求头和状态值,请将headersstatus参数传递给上面这些函数,下面以json为例
from sanic.response import json

@app.route("/json")
async def get_json(request):
    return json({"name":"老张"},headers={"age":18},status=403)

访问此接口后,会发现原来本应是200的状态值变成了403,而且请求头信息中增加了{"age":18}

你可能感兴趣的:(sanic)