flask中request的一些方法

  • 首先from flask import request

1.request.path

2.request.host

3.request.host_url

from flask import Flask, request

app = Flask(__name__)
@app.route('/')
def index():
print(request.path) #/
print(request.host) #127.0.0.1:5000
print(request.host_url) #http://127.0.0.1:5000/
return 'hello'
if __name__ == '__main__':
app.run(debug=True)

4.request.method   获取请求方式

from flask import Flask, request

app = Flask(__name__)
@app.route('/')
def index():
print(request.method) #GET
if request.method=="GET":
print('use GET method') #use GET method
return 'hello'
if __name__ == '__main__':
app.run(debug=True)

5.request.args         获取url参数

  • 获取字典的key值有两种方法,分别是索引['id']和get方法,如果索引的value值错误会出现一个keyerro的错误,如果是get的value的值错误会是None
  • request.args.get('id')   #拿到url单独的一个参数
  • request.args.to_dict()  #得到一个字典
  • request.args.to_dict().get('id') #字典通过get方法获取值
  • request.args.to_dict()['id']  #字典通过索引获取值
from flask import Flask, request
app = Flask(__name__)
@app.route('/')
def index():
#获取url中的参数,比如url为http://127.0.0.1:5000/?id=1&name=2,通过request.args得到一个
#类似于字典的元组ImmutableMultiDict([('id', '1'), ('name', '2')])
print(request.args) #ImmutableMultiDict([('id', '1'), ('name', '2')])
print(request.args.get('id')) #拿到了id的值1
print(request.args.get('name')) #拿到了name的值2
arg=request.args.to_dict()
print(arg) #拿到了一个字典{'id': '1', 'name': '2'}
print(arg['id']) #通过索引拿到了id的值1
print(arg.get('id')) #通过get方法拿到了id的值1
return 'hello'
if __name__ == '__main__':
app.run(debug=True)

6.request.form          获取FormData 数据

  • request.form.to_dict()   #获取一个登陆信息的字典

7.request.files            接收FormData中的文件

  • request.files.to_dict() #生成一个字典
  • request.file.get('文件名')  # 通过文件名获取文件
  • request.file.get('文件名').save(file.filename) #通过文件名获取文件之后以原文件名保存到当前目录下
  • request.file.get('文件名').save('新文件名') #通过文件名获取文件之后以新文件名保存到当前目录下
from flask import Flask, request, render_template
app = Flask(__name__)
@app.route('/login',methods=['POST','GET']) #如果出现状态码405是因为没有加上methods方法
def login():
if request.method=="GET":
return render_template('login2.html')
else:
print(request.form)#获得ImmutableMultiDict([('username', '123')])
print(request.form.to_dict())#获得一个字典{'username': '123'}
print(request.files)#获取ImmutableMultiDict([('my_file', <FileStorage: '1.jpg' ('image/jpeg')>)])
print(request.files.to_dict())#获取字典{'my_file': <FileStorage: '1.jpg' ('image/jpeg')>}
print(request.files.get('my_file'))#获取key值<FileStorage: '1.jpg' ('image/jpeg')>
file=request.files.get('my_file')
file.save(file.filename) #保存文件到目录下
return '登录成功'
if __name__ == '__main__':
app.run(debug=True)
//login.html页面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="" method ='post' enctype="multipart/form-data">#enctype="multipart/form-data
<input type="text" name="username">#输入框
<input type="file" name="my_file"> #提交文件的选择框
<input type="submit" value="提交">#按钮
</form>
</body>
</html>

 

8.request.json          请求头 带有Content-Type:application/json   请求体中的数据自动序列化至此,生成一个字典,而且在data中依然

           存储着以byte形式的原始数据
9.request.data           获取请求体中的原始数据   是一个字节流b"”

10request.values       这个是获取args+form  慎用,有坑

flask基础---第三篇的更多相关文章

  1. NHibernate 映射基础(第三篇) 简单映射、联合主键

    NHibernate 映射基础(第三篇) 简单映射.联合主键 NHibernate完全靠配置文件获取其所需的一切信息,其中映射文件,是其获取数据库与C#程序关系的所有信息来源. 一.简单映射 下面先来 ...

  2. Python基础第三篇

    一.collections系列 Counter是对字典类型的补充,用于追踪值的出现次数,具备字典的所有功能 + 自己的功能 1.计数器Counter import collections a='aba ...

  3. Python【基础第三篇】

    set集合 s1=set() 集合特点: 访问速度快 没有重复项 collections系列(数据类型容器模块) 一.计数器(Counter) Counter是对字典类型的补充,用于追踪值的出现次数. ...

  4. Django基础第三篇

    一.ORM操作 1.常用字段和参数 Autofied 自增的整形字段,必填参数primary_key=True,  则成为数据库的主键,如无该字段,django自动创建 IntegerField 一个 ...

  5. bootstrap基础学习三篇

    bootstrap的排版 1.标题 Bootstrap 中定义了所有的 HTML 标题(h1 到 h6)的样式 2.代码如下: <div class="container"& ...

  6. python基础-第三篇-函数编程

    基本数据类型之set set是无序不允许重复的集合 set创建:s = set() 创建空集合  s = {11,22,33} 转换s = set(可迭代数据) li = [11,22,33,44] ...

  7. java基础第三篇

    6.Java 中的容器(重点) a.变量:变量是一个容器,它存储的单个值 //int i=3; 1.局部变量:定义在方法中,没有默认值 2.成员变量:定义在类中方法外,这个事物的属性(特征)定义为成员 ...

  8. Java笔记(基础第三篇)

    面向对象的特点: 封装 继承 多态 类的构造方法 如果在类中定义的构造方法都不是无参的构造方法,则编译器不会为类设置一个默认的无参构造方法,当视图调用无参构造方法实例化一个对象时,编译器会报错,所以只 ...

  9. 第三篇 Flask 中的 request

    第三篇 Flask 中的 request   每个框架中都有处理请求的机制(request),但是每个框架的处理方式和机制是不同的 为了了解Flask的request中都有什么东西,首先我们要写一个前 ...

随机推荐

  1. iOS进阶之如何进行 HTTP Mock(转载)

    这篇文章会对 OHHTTPStubs 源代码的分析,其实现原理是建立在 NSURLProtocol 的基础上的,对这部分内容不了解的读者,可以阅读这篇文章 iOS 开发中使用 NSURLProtoco ...

  2. radhat6.6上安装oracle12c RAC (一)

    软件环境:VMware.redhat6.6.oracle12c(linuxx64_12201_database.zip).12cgrid(linuxx64_12201_grid_home.zip) 一 ...

  3. [c/c++] programming之路(26)、结构体

    一.初始化字符串 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #include&l ...

  4. BZOJ-1587|前缀和 预处理 dp||叶子合并leaves

    叶子合并leaves Description 在一个美丽的秋天,丽丽每天都经过的花园小巷落满了树叶,她决定把树叶堆成K堆,小巷是笔直的 共有N片树叶(树叶排列也是笔直的),每片树叶都有一个重量值,并且 ...

  5. Valse2019笔记——弱监督视觉理解

    程明明(南开大学):面向开放环境的自适应视觉感知 (图片来自valse2019程明明老师ppt) 面向识别与理解的神经网络共性技术 深度神经网络通用架构 -- VggNet(ICLR'15).ResN ...

  6. 出错:(unicode error) 'unicodeescape' codec can't decode bytes in position 8-9: malformed \N character escape

    报错原因:python 中 \N 是换行的意思.这里要把 N 前面的 \ 转义一下.用  \\  代替即可. Nokia_mac = np.loadtxt('data\oui\\NokiaMac201 ...

  7. c#数据库事务锁类型

    一.脏读.不可重复读.幻象读的区别   1.脏读:包含未提交数据的读取.例如,事务 a 更改了某行(数据库已发生更改,但尚未提交,有可能发生回滚),事务 b 在事务 a 提交更改之前读取已更改的行.如 ...

  8. Python3中urllib模块的使用

    转载自:https://www.cnblogs.com/php-linux/p/8365941.html 1.基本方法 urllib.request.urlopen(url, data=None, [ ...

  9. python2.7安装

    下载地址:https://www.python.org/downloads/release/python-2716/ 尽量使用VPN,不然会很慢 安装后需要配置环境变量

  10. 【转】 glibc detected *** corrupted double-linked list:错误的原因有如下三种可能

    一个多线程的大程序运行的时候崩掉了,屏幕上打出这个:   *** glibc detected *** corrupted double-linked list: 0xb78381d8 *** 三个原 ...