第二章 Flask——Flask中的request
第二章 Flask——Flask中的request
一、request.method
二、request.form
三、request.args
四、request.values
五、request.cookies
六、request.headres
七、request.data
八、request.files
九、request.json
十、request.其他
介绍那么多之前先做一件事,那就是——导入模块,没错,Flask框架连request都是导入的
from flask import Flask,request
一、request.method
查看请求方式
print(request.method) # POST 看来可以使用这种方式来验证请求方式了
二、request.form
作用:
获取POST请求中的数据
前提是要在装饰器内写上允许的请求方式methods=["POST"]
@app.route('/login',methods=["POST","GET"]) # 路由 def login(): # 视图函数# print(request.args,type(request.args))# id = request.args.get("id")# username = request.args.get("username")print(request.form,type(request.form))username = request.form.get("username")password = request.form.get("password")print(username,password)return render_template("template.html")
html
<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>template</title> </head> <body><h1>请登录</h1><form action="/login" method="post">用户名:<input type="text" name="username">密码:<input type="password" name="password"><input type="submit" value="提交"></form> </body> </html>
取值方式与下面request.args相同,都打印了type类型是一样的
三、request.args
作用:
获取GET请求中的数据
获取url地址中的参数
@app.route('/login') # 路由 def login(): # 视图函数print(request.args,type(request.args))id = request.args.get("id")username = request.args.get("username")print(id,username)return render_template("template.html")
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.values
作用:
接收所有参数
取值方式与上面两个方法相同。
但是有一点需要注意
我们修改一下html代码
html
<form action="/login?id=1&age=20&username=xxx" method="post">用户名:<input type="text" name="username">密码:<input type="password" name="password"><input type="submit" value="提交"> </form>
flask.py
@app.route('/login',methods=["POST","GET"]) # 路由 def login(): # 视图函数# print(request.args,type(request.args))# id = request.args.get("id")# username = request.args.get("username")print(request.values,type(request.values))username = request.values.get("username")password = request.values.get("password")print(username,password)return render_template("template.html")
当用户输入用户名为admin,密码为123时,我们看下收到的数据
CombinedMultiDict([ImmutableMultiDict([('id', '1'), ('age', '20'), ('username', 'xxx')]), ImmutableMultiDict([('username', 'admin'), ('password', '123')])]) <class 'werkzeug.datastructures.CombinedMultiDict'> xxx 123 127.0.0.1 - - [29/Oct/2018 21:26:50] "POST /login?id=1&age=20&username=xxx HTTP/1.1" 200 -
所以我们可以得出结论:
!!!如果url和form中的Key重名的话,form中的同名的key中value会被url中的value覆盖!!!
五、request.cookies
作用:
存在浏览器端的字符串儿也会一起带过来
print(request.cookies)
六、request.headres
作用:
用来获取本次请求的请求头
print(type(request.headers))"""Host: 127.0.0.1:5000User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2Accept-Encoding: gzip, deflateReferer: http://127.0.0.1:5000/homeContent-Type: application/x-www-form-urlencodedContent-Length: 26Cookie: csrftoken=vDIozqveCEfArdYXlM6goHVlSQEn7h4bDygNphL2Feas60DiM2di0jlqKfxo7xhAConnection: keep-aliveUpgrade-Insecure-Requests: 1Cache-Control: max-age=0"""
七、request.data
作用:
如果处理不了的就变成字符串儿存在data里面
你一定要知道 request 是基于 mimetype 进行处理的
mimetype的类型 以及 字符串儿 : http://www.w3school.com.cn/media/media_mimeref.asp
如果不属于上述类型的描述,request就会将无法处理的参数转为Json存入到 data 中
其实我们可以将 request.data , json.loads 同样可以拿到里面的参数
八、request.files
作用:
保存文件
九、request.json
作用:
获取所有json数据
如果在请求中写入了 "application/json" 使用 request.json 则返回json解析数据, 否则返回 None
十、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/
转载于:https://www.cnblogs.com/neymargoal/p/9873226.html
第二章 Flask——Flask中的request相关推荐
- 攻下《JavaScript高级程序设计》——第二章 在HTML中使用JavaScript
从上一章我们知道了,JavaScript是一种专门为网页交互而设计的脚本语言,那么,它就免不了和HTML打交道,所以在设计JavaScript的时候,Netscape首要面临的就是,怎么让HTML和J ...
- 【数字信号处理】 第二章、时域中的离散时间信号
前言 学而时习之,不亦乐乎? --<论语·学而> Is it not pleasant to learn with a constant perseverance and applicat ...
- 管理系统中计算机应用第二章答案,管理系统中计算机应用第二章习题及答案.pdf...
第二章 应用信息系统 一.单项选择题: 1.根据系统目的及环境许可,将所需的原始数据输入系统的功能是 ()2-54 A.信息存储 B.信息控制 C.信息处理 D.信息采集 答案:D 解析:信息的采集是 ...
- 《风尚坐火箭学习vue》-- 第二章:页面中输出hello Vue
前言:前端框架千千万,独有vue占一半 我是风尚,让我们一起坐火箭去学习Vue 图片来自vue官网 第二章:hello Vue 上章回顾:风尚内心答应了跟白发老头学习vue 风尚内心答应了跟白发老头学 ...
- 《avascript 高级程序设计(第三版)》 ---第二章 在HTML中使用Javascript
本章主要讲解了,怎么在HTML中使用: 1.<script src=""></script> 属性:defer="defer" 表示脚本 ...
- (Python高级编程)第二章:Python中的魔法函数
文章目录 一:什么是魔法函数 (1)魔法函数 (2)作用 二:Python中的魔法函数 (1)字符串表示 (2)集合序列相关 (3)迭代相关- (4)可调用 (5)with上下文管理器 (6)数制转换 ...
- 第二章:泥潭中的群体
由老青蛙一手推动的"公路基建项目",在和区政府签了一个意向书之后,很快就尘埃落定了.三角鳄因为这项意向书,其政绩在同类中显得极为突出,上级领导对此大为嘉许,没多久就将三角鳄提拨到了 ...
- 第二章 在HTML中使用JavaScript
2.1 <script> 元素 向HTML中插入JavaScript的主要方法就是使用 <script> 标签 <script>// 嵌入式 </script ...
- WCF 第二章 契约 WSDL中的操作名字、类型、操作和命名空间
WCF 根据服务端源代码中定义的内部类名称和属性来生成外部暴露服务实现.这些实现通过服务中的MEX终结点暴露出来并在设计阶段时被客户端以WSDL形式使 用.接下来在客户端,WSDL会被用来写一些代码来 ...
- C++挖掘程序本质(第二章C++面向对象-中)李明杰-M了个J 配套教材
文章目录 前言 1. 内存管理(4张内存图-非常重要) 1.1 类中的成员变量,不需要主动回收 1.2 内存泄露 1.3 创建对象(栈),对象内部申请栈空间 ☆(1/4张内存图,十分重要) 1.4 创 ...
最新文章
- Android中Service生命周期、启动、绑定、混合使用
- Real World Kanban作者访谈
- 华为 会议室分配时间最长_智慧办公就是现在!华为企业智慧屏系列全新亮相...
- nginx1.11.*版本追加安装sticky模块出现问题解决方法
- C#调用 Halcon引擎执行代码
- Java IO ---学习笔记(数据流)
- Kudu : NonRecoverableException: Got out-of-order key column
- 百度爬虫爬到虚拟链接 网站被黑_什么是网络爬虫?原理是什么?种类有多少?...
- JavaScript或MyEclipse—如何解决js文件导入到MyEclipse工程后出错?
- MATLAB快速入门(一)
- linux有类似酷狗qq音乐软件,除了网易云QQ音乐,这些小众音乐APP同样值得推荐。...
- 多么痛的领悟,只有程序员才知道的12个人艰不拆的真相
- 公安部授权二代身份证阅读器的生产厂家(共十家)
- PPT模板 | 湖南农业大学汇报通用PPT模板
- 微信是一个计算机信息系统么,电脑微信不登录也能收到信息怎么办啊
- STM32用cube配置FATFS模式下SPI读写SD卡
- LocalSolver-全领域、超大规模混合变量数学规划介绍
- 三天还不够!SACC2018技术演讲部分完美收官
- 基于openssl的EVP对称加密C语言实战案例
- 科技创新—人工智能应用技术的出现