在 Python Flask 中 request 的属性简单解释
因为写代码的时候经常会需要用到,但又记不住,只能靠写下来了,可能并不全,等下次遇到再做添加。
以下就是一些在 python 的Flask 中常用到的 request 对象中的常用属性。
# 获取请求地址
path = request.path
request.path 返回的是客户端请求的路径部分,即不包括协议、主机名、端口号和查询参数的 URL 路径。
# 获取请求方法
method = request.method
获取当前请求的 HTTP 方法,例如 GET、POST、PUT、DELETE 等。
# 请求来源的ip
ip = request.remote_addr
获取客户端的 IP 地址,将获取到的 IP 地址赋值给变量 ip,以便后续使用。需要注意的是,有些代理服务器可能会改变客户端的 IP 地址,因此在使用时需要谨慎。如果你需要获取真实的客户端 IP 地址,可以使用 Flask 的扩展 Flask-HTTPAuth。
# 获取form表单的数据
form = request.form
返回的是客户端提交的包含表单数据的字典。它只会返回提交方式为 POST 的请求中的表单数据,如果请求方式为 GET,则返回空字典。
需要注意的是,如果客户端提交的是一个空表单,那么 request.form 也会返回一个空字典。如果你需要判断客户端是否提交了表单数据,可以使用 request.method 来判断请求方式是否为 POST,然后再使用 Python 的 len() 函数来判断字典中是否有数据。
# 获取查询字符串/表单数据
value = request.values
返回的是客户端提交的所有数据,包括表单数据和查询参数。它会返回一个字典,其中包含了客户端提交的所有数据,包括 GET 请求中的查询参数和 POST 请求中的表单数据。
# 获取头部信息
headers = request.headers
返回的是客户端发送的请求头部信息,它会返回一个字典,其中包含了所有的请求头部信息。
HTTP 请求头部包含了客户端发送请求时的一些附加信息,例如浏览器类型、所使用的操作系统、请求的语言、请求的时间、请求的来源等等。服务器可以使用这些信息来判断客户端的身份、优化响应、记录日志等等。
# 获取发起请求的浏览器的信息
User_Agent = request.headers['User-Agent']
User-Agent 是 HTTP 请求头部中的一个字段,它用来标识客户端所使用的浏览器、操作系统、设备等信息。
# 主机
host = request.headers['Host']
Host 是 HTTP 请求头部中的一个字段,它用来标识客户端请求的主机名或 IP 地址。
# 获取指定参数
name = request.args.get('name', "没有获取到name")
获取客户端请求中的查询参数,其中 name 是查询参数的名称,"没有获取到name" 是默认值,如果客户端请求中没有包含 name 参数,则会返回默认值。
# 环境
environ = request.environ
environ 是一个字典,它包含了客户端请求的所有相关信息,例如客户端的 IP 地址、请求的方法、协议类型、请求头部信息等等。
# 完整路径
full_path = request.full_path
返回的是一个字符串,包含了客户端请求的完整路径。
# 获取完整 URL 地址
url = request.url
获取客户端请求的完整 URL 地址,包括协议类型、主机名、路径和查询参数。
# 获取基础 URL 地址
base_url = request.base_url
获取客户端请求的基础 URL 地址,包括协议类型、主机名和路径,但不包括查询参数。
# 获取根 URL 地址
url_root = request.url_root
获取客户端请求的根 URL 地址,包括协议类型、主机名和应用程序路径,但不包括查询参数。
# 是否为XMLHTTPRequest请求
si_xhr = request.is_xhr
返回一个布尔值,用于表示当前请求是否是通过 XMLHttpRequest 发起的异步请求,如果是,则返回 True,否则返回 False。
# 当前的蓝图名
blueprint = request.blueprint
返回一个字符串,表示当前请求所属的蓝图名称。如果当前请求不属于任何蓝图,则返回 None。
# 根节点, 当前执行的函数
endpoint = request.endpoint
返回一个字符串,表示当前请求所对应的视图函数名称。如果当前请求没有匹配到任何视图函数,则返回 None。
# 视图参数
view_args = request.view_args
返回一个字典,表示当前请求所匹配的动态路由参数。如果当前请求没有匹配到任何路由,则返回一个空字典。