Sanic框架请求与响应实例分析
本文实例讲述了Sanic框架请求与响应。分享给大家供大家参考,具体如下:
前面介绍了Sanic框架的路由,这里接着介绍Sanic框架的请求与响应。
简介
Sanic是一个类似Flask的Python3.5+Web服务器,它的写入速度非常快。除了Flask之外,Sanic还支持异步请求处理程序。这意味着你可以使用Python3.5中新的闪亮的异步/等待语法,使你的代码非阻塞和快速。
前言:Sanic最低支持Python3.5,如果需要学习Sanic,请先下载版本不低于3.5的Python包
请求数据
当一个端点收到一个HTTP请求时,路由功能被传递到一个request对象。以下变量可以作为request对象的属性访问:
- json:JSON数据
@app.route("/post_data",methods=["POST"]) asyncdefpost_data(request): #将打印传递过来的JSON数据 print(request.json) returntext("itisok!")
- args:查询字符串变量。查询字符串是类似于URL的部分?name=laozhang&age=20。如果URL被解析,那么args字典将如下所示:{"name":["laozhang"],"age":[20]}
- raw_args:在许多情况下,我们需要获取压缩程度低的字典中的url参数。对于之前的URL?name=laozhang&age=20,raw_args字典将如下所示:{"name":"laozhang","age":20}
- file:文件对象字典,具有名称,正文和类型的文件列表
@app.route("/post_file_data",methods=["POST"]) asyncdefpost_file_data(request): info=request.files.get("file") print(info.name) print(info.type) print(info.body) returntext("itisok!")
- form:表单数据,form字典将如下所示:{"name":["laozhang"]}
@app.route("/post_form_data",methods=["POST"]) asyncdefpost_form_data(request): name=request.form.get("name") returntext("itisok!")
- body:原始数据。无论内容类型如何,该属性都允许检索请求的原始数据。byte类型
- headers:获取请求表头的不区分大小写的字典。dict类型
- ip:IP地址,str类型
- port:端口,str类型
- socket:请求者的IP地址和端口,(IP地址,端口)。tuple类型
- app:对处理请求的Sanic应用程序对象的引用。
@appr.route("/get_app_info") asyncdefget_app_info(request): print(request.app.config) returntext("itisok!")
- url:请求的完整URL,如:http://localhost:5000/get_app_info
- scheme:获取与请求关联的URL方案:http或https
- host:获取与请求关联的主机
- path:获取请求的路径,如:/get_app_info
- query_string:获取查询的字符串,如:name=zhangsan或者为一个空白字符串
- uri_template:获取匹配路由处理程序的模板,如:/get/
- token:授权标头的值
get与getlist
当我们访问一个GET请求,并传入相关参数时,如下的请求:
@app.route("/get_info") asyncdefget_info(request): print(request.args.get("name")) print(request.args.getlist("name") returntext("itisok!")
当我们传入一个name为laozhang时,在上面有提到,args字典将会是{"name":["laozhang"],所以,访问上面的路由,将会打印如下结果:
laozhang
["laozhang"]
响应
使用sanic.response模块中的函数来创建响应
纯文本:
fromsanic.responseimporttext @app.route("/text") asyncdefget_text(request): returntext("itistextresponse!")
HTML:
fromsanic.responseimporthtml @app.route("/html") asyncdefget_html(request): returnhtml("itishtml!
")
JSON:
fromsanic.responseimportjson @app.route("/json") asyncdefget_json(request): returnjson({"name":"laozhang"})
FILE:
fromsanic.responseimportfile @app.route("/file") asyncdefget_file(request): returnawaitfile("/xx/aa/abc.png")
切记,不能少了await关键字
STREAM:
fromsanic.responseimportstream @app.route("/stream") asyncdefget_stream(request): asyncdefstream_fn(response): response.write("abc") response.write("def") returnstream(stream_fn,content_type="text/plain")
文件流:针对大文件,上面文件与流的组合
fromsanic.responseimportfile_stream @app.route("/file_stream") asyncdefget_file_stream(request): returnawaitfile_stream("/xx/aa/abc.png")
切记,不能少了await关键字
重定向:
fromsanic.responseimportredirect @app.route("/redirect") asyncdefget_redirect(request): returnredirect("/json")
RAW:未编码的body响应
fromsanic.responseimportraw @app.route("/raw") asyncdefget_raw(request): returnraw(b"itisrawdata")
访问此接口后,将会立即下载一个名为raw的文件,里面包含内容itisrawdata
修改请求头和状态值:如果需要修改请求头和状态值,请将headers和status参数传递给上面这些函数,下面以json为例
fromsanic.responseimportjson @app.route("/json") asyncdefget_json(request): returnjson({"name":"老张"},headers={"age":18},status=403)
访问此接口后,会发现原来本应是200的状态值变成了403,而且请求头信息中增加了{"age":18}
更多关于Python相关内容可查看本站专题:《Python入门与进阶经典教程》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。