Python Web框架Sanic response raw() 函数用法和示例

发表时间:2020-02-18

response.raw() 功能: Sanic 返回二进制数据给浏览器。

Sanic response.raw() 函数

response.raw() 语法

def raw(
    body,
    status=200, headers=None,
    content_type="application/octet-stream;
):

response.raw() 参数

  • body:响应要返回的 bytes 字符串,不是 str
  • status:默认 http 状态码200,正常返回不要修改;
  • headers:自定义 http 响应头;
  • content_type:纯文本的content type,不要修改;

raw() text() 非常像,不同的是, raw() 传入的 body 必须是 bytes 字符串(即, str 编码后的结果)。这里面, body 是必需的参数,可以通过传入 headers 来自定义响应头,其它参数不要修改。
比如,自定义响应头headers:


return raw('Welcom to 猿人学Python',
            headers={'X-Serverd-By': 'YuanRenXue Python'})

response.raw() 返回值

返回一个 HTTPResponse 类的实例。多数情况下,路由函数直接返回这个实例。当需要再进一步处理响应(比如,设置响应cookies)时,要把它赋值给一个变量。

response.raw() 例子

from sanic import Sanic
from sanic import response


app = Sanic()


@app.route('/raw')
async def raw(request):
    msg = 'Welcom to 猿人学Python'
    return response.raw(
        msg.encode('utf8'),
        headers={'X-Serverd-By': 'YuanRenXue Python'}
    )


if __name__ == '__main__':
    app.run(host='127.0.0.1', port=8888)

注意:传入的字符串必须是编码后的 bytes

通过 curl 来查看raw响应:

curl -i http://127.0.0.1:8888/raw

结果如下,可以看到我们自定义的headers X-Serverd-By: YuanRenXue Python


HTTP/1.1 200 OK
Connection: keep-alive
Keep-Alive: 5
X-Serverd-By: YuanRenXue Python
Content-Length: 25
Content-Type: application/octet-stream

Welcom to 猿人学Python

请注意 Content-Type 与其它响应函数的不同。

文章来源互联网,如有侵权,请联系管理员删除。邮箱:417803890@qq.com / QQ:417803890

微配音

Python Free

邮箱:417803890@qq.com
QQ:417803890

皖ICP备19001818号-4
© 2019 copyright www.pythonf.cn - All rights reserved

微信扫一扫关注公众号:

联系方式

Python Free