Flask中的request

1.前言

每个框架中都有除了请求的机制(request),但是每个框架的处理方式和机制是不同的

为了了解Flask的request中都有什么东西,首先我们要写一个前后端的交互

基于HTML + Flask 写一段前后端的交互

先写一段HTML From表单中提交方式是POST action地址是 /req

<!DOCTYPE html>
<html lang="en">
<
head> <meta charset="UTF-8"> <title>Title</title>
</
head>
<
body>
<
h1>我是HOME</h1>
<
form method="post" action=""> <input type="text" name="user"> <input type="text" name="pwd"> <input type="submit" value="提交">
</
form>
</
body>
</
html>

首先要从 flask 包中导入 request 模块 , 至于为什么要导入 request 呢? 这里不做解释,暂时你就知道 request 如果要用,需要导入

from flask import Flask, request

app = Flask(__name__)

@app.route("/req", methods=["POST"])
def req(): print(request.method) # POST看来可以使用这种方式来验证请求方式了 print(request.form) # ImmutableMultiDict([('user','haha'), ('pwd','123')]) # ImmutableMultDict 它看起来像是Dict就用Dict的方法取值试一下 print(request.form["user"]) # haha print(request.form.get("pwd")) # 123 # 看起来全部猜对了,ImmutableMultiDict似乎是个字典 print(list(request.form.keys())) # ["user","pwd"]看起来又猜对了 return "OK 200"

解释一个 @app.route("/req",methods=["POST"]) :

methods=["POST"]  代表这个url地址只允许 POST 请求,是个列表也就是意味着可以允许多重请求方式,例如GET之类的

2.request.method 前端是用什么方式提交的

Flask的request中给我们提供了一个method属性里面保存的就是前端的请求方式

print(request.method) # POST 看来可以使用这种方式来验证请求方式了

3.request.form 举例

Form表单中传递过来的值 使用 request.form 中拿到

    print(request.form)  # ImmutableMultiDict([('user', 'haha'), ('pwd', '123')])
    # ImmutableMultiDict 它看起来像是的Dict 就用Dict的方法取值试一下吧
    print(request.form["user"])  # haha
    print(request.form.get("pwd"))  # 123
    # 看来全部才对了, ImmutableMultiDict 似乎就是个字典,再来玩一玩它
    print(list(request.form.keys()))  # ['user', 'pwd'] 看来是又才对了
    #如果以上所有的方法你都觉得用的不爽的话
    req_dict = dict(request.form)
    print(req_dict)  # 如果你觉得用字典更爽的话,也可以转成字典操作(这里有坑)

4.request.args 能看到的Url参数全在里面

request.args 中保存的是url中传递的参数

from flask import Flask, request

app = Flask(__name__)

@app.route("/req", methods=["GET", "POST"])
def req(): print(request.args) return "OK 200" app.run(debug=True)

然后使用URL地址直接传递参数

 

然后会在控制台中看到 ImmutableMultiDict([('id', '1'), ('age', '20')])

这不是和刚才一样的吗,没错!

    print(request.args)  # ImmutableMultiDict([('id', '1'), ('age', '20')])
    print(request.args["id"])  # 1
    print(request.args.get("age"))  # 20
    print(list(request.args.keys()))  # ['id', 'age']
    print(list(request.args.values()))  # ['1', '20']
    req_dict = dict(request.args)  # {'id': ['1'], 'age': ['20']}
    print(req_dict)

request.args与request.form的区别就是:

  • request.args是获取url中的参数
  • request.form是获取form表单中的参数

5.request.values:只要是个参数我都要

改动前端代码:

<!DOCTYPE html>
<html lang="en">
<
head> <meta charset="UTF-8"> <title>Title</title>
</
head>
<
body>
<
h1>我是HOME</h1>
<
form method="post" action="/req?id=1&age=20"> <input type="text" name="user"> <input type="text" name="pwd"> <input type="submit" value="提交">
</
form>
</
body>
</
html>

这是让我们在使用form表单提交的同时使用url参数提交

print(request.values)  # CombinedMultiDict([ImmutableMultiDict([('id', '1'), ('age', '20')]), ImmutableMultiDict([('user', 'haha'), ('pwd', '123')])])print(request.values.get("id"))  # 1print(request.values["user"])  # haha

# 这回喜欢直接操作字典的小伙伴们有惊喜了! to_dict() 方法可以直接将我们的参数全部转为字典形式print(request.values.to_dict()) # {'user': 'haha', 'pwd': '123', 'id': '1', 'age': '20'}

注意啦!注意啦!

# 注意这里的坑来啦! 坑来啦!
# 如果url和form中的Key重名的话,form中的同名的key中value会被url中的value覆盖
# http://127.0.0.1:5000/req?id=1&user=20
print(request.values.to_dict())  # {'user': 20 'pwd': '123', 'id': '1'}

6..request.cookies:存在浏览器端的字符串也会一起带过来

前提是你要开启浏览器的 cookies

request.cookies 是将cookies中信息读取出来

7.request.headres:请求头的秘密

用来获取本次请求的请求头

print(type(request.headers))

""" Host: 127.0.0.1:5000 Connection: keep-alive Cache-Control: max-age=0 Upgrade-Insecure-Requests: 1 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.110 Safari/537.36 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8 Accept-Encoding: gzip, deflate, br Accept-Language: zh-CN,zh;q=0.9
"""

8.request.data:如果处理不了的就变成字符串存在data里面

你一定要知道 request 是基于 mimetype 进行处理的

mimetype的类型 以及 字符串儿 : http://www.w3school.com.cn/media/media_mimeref.asp

如果不属于上述类型的描述,request就会将无法处理的参数转为Json存入到 data 中

其实我们可以将 request.data , json.loads 同样可以拿到里面的参数

9.request.files:给我一个文件我帮你保管

如果遇到文件上传的话,request.files 里面存的是你上传的文件,但是 Flask 在这个文件的操作中加了一定的封装,让操作变得极为简单

首先改下前端代码:

<!DOCTYPE html>
<html lang="en">
<
head> <meta charset="UTF-8"> <title>Title</title>
</
head>
<
body>
<
h1>我是HOME</h1>
<
form method="post" action="" enctype="multipart/form-data"> <input type="file" name="file"> <input type="submit" value="提交">
</
form>
</
body>
</
html>

后端:

    print(request.files)  # ImmutableMultiDict([('file', <FileStorage: 'heihei.txt' ('text/plain')>)])
    print(request.files["file"])  # <FileStorage: 'heihei.txt' ('text/plain')>
    my_file = request.files["file"]
    my_file.save("haha.txt")  # 保存文件,里面可以写完整路径+文件名

这样我们就成功的保存了一个名叫 "haha.txt" 的文件了,操作还是很简单的

10.request.:获取各种路径,这些方法没必要记,但是要知道它存在

    # 获取当前的url路径
    print(request.path)# /req
    # 当前url路径的上一级路径
    print(request.script_root) #    # 当前url的全部路径
    print(request.url) # http://127.0.0.1:5000/req
    # 当前url的路径的上一级全部路径
    print(request.url_root ) # http://127.0.0.1:5000/

11.request.json:前提你得告诉是json

如果在请求中写入了 "application/json" 使用 request.json 则返回json解析数据, 否则返回 None

12.汇总:

request.method # 请求方式
request.form # 存放FormData中的数据 to_dict 序列化成字典
request.args # 获取URL中的数据 to_dict 序列化成字典
request.url # 访问的完整路径
request.path # 路由地址
request.host # 主机地址
request.values # 获取 FormData and URL中的数据 不要用to_dict
request.json  # 如果提交时请求头中的Content-Type:application/json 字典操作
request.data  # 如果提交时请求头中的Content-Type 无法被识别 将请求体中的原始数据存放 byte
request.cookies # 获取Cookie中的数据
request.headers # 获取请求头
request.files # 序列化文件存储 save()

 

posted @ 2019-01-15 15:25  骑驴老神仙  阅读(1027)  评论(2编辑  收藏  举报