在进行Flask开发中,前端须要发送不一样的请求及各类带参数的方式,好比GET方法在URL后面带参数和POST在BODY带参数,有时候又是POST的表单提交方式,这个时候就须要从request
提取参数。这篇文章是总结如何使用request
。html
在Flask的官方文档中是这样介绍request
的:前端
对于 Web 应用,与客户端发送给服务器的数据交互相当重要。在 Flask 中由全局的 request 对象来提供这些信息。python
从Flask模块导入request
:json
from flask import request
下面是request可以使用的属性,其中黑体是比较经常使用的。flask
form
一个从POST和PUT请求解析的 MultiDict(一键多值字典)。api
args
MultiDict,要操做 URL (如 ?key=value )中提交的参数可使用 args 属性:服务器
searchword = request.args.get('key', '')
values
CombinedMultiDict,内容是form
和args
。
可使用values替代form和args。markdown
cookies
顾名思义,请求的cookies,类型是dict。cookie
stream
在可知的mimetype下,若是进来的表单数据没法解码,会没有任何改动的保存到这个·stream·以供使用。不少时候,当请求的数据转换为string时,使用data
是最好的方式。这个stream只返回数据一次。app
headers
请求头,字典类型。
data
包含了请求的数据,并转换为字符串,除非是一个Flask没法处理的mimetype。
files
MultiDict,带有经过POST或PUT请求上传的文件。
environ
WSGI隐含的环境配置。
method
请求方法,好比POST、GET。
path
http://www.example.com/myapplication/page.html?x=y
名称 | 内容 |
---|---|
path | /page.html |
script_root | /myapplication |
base_url | http://www.example.com/myapplication/page.html |
url | http://www.example.com/myapplication/page.html?x=y |
url_root | http://www.example.com/myapplication/ |
is_xhr
若是请求是一个来自JavaScript XMLHttpRequest
的触发,则返回True
,这个只工做在支持X-Requested-With
头的库而且设置了XMLHttpRequest
。
blurprint
蓝本名字。
endpoint
endpoint匹配请求,这个与view_args
相结合,但是用于重构相同或修改URL。当匹配的时候发生异常,会返回None。
get_json(force=False, silent=False, cache=True)
json
若是mimetype
是application/json
,这个参数将会解析JSON数据,若是不是则返回None。
可使用这个替代get_json()方法。
max_content_length
只读,返回MAX_CONTENT_LENGTH
的配置键。
module
若是请求是发送到一个实际的模块,则该参数返回当前模块的名称。这是弃用的功能,使用blueprints
替代。
routing_exception = None
若是匹配URL失败,这个异常将会/已经抛出做为请求处理的一部分。这一般用于NotFound
异常或相似的状况。
url_rule = None
内部规则匹配请求的URL。这可用于在URL以前/以后检查方法是否容许(request.url_rule.methods) 等等。
默认状况下,在处理请求函数中写下 print('request.url_rule.methods', request.url_rule.methods)
会打印:
request.url_rule.methods {‘GET’, ‘OPTIONS’, ‘HEAD’}
view_args = None
一个匹配请求的view参数的字典,当匹配的时候发生异常,会返回None。
更多api例子参考:
https://www.programcreek.com/python/example/60711/flask.request.data