Flask response响应的具体使用


Posted in Python onJuly 15, 2021
目录
  • 引言
  • response响应
    • 元组形式响应
    • make_response函数
    • 返回json格式数据
  • 其他特殊响应
    • redirect() 重定向
    • abort() 中断
  • 源代码

 

引言

客户端发送 http 请求给 Flask程序,Flask 调用视图函数后,会将其返回值作为响应的内容。大多情况下,响应就是一个简单的字符串,作为 Html 页面回送客户端。
但 http 协议需要的不仅是作为请求响应的字符串。http 响应中有一个很重要的部分是状态码,Flask设为200,代表请求已被成功处理。

 

response响应

 

元组形式响应

如果视图函数返回的响应还需要使用不同的状态码,那么可以把数字代码作为第二个返回值,添加到响应文本之后

from flask import Flask

app = Flask(__name__)


# 以元组形式返回响应信息
@app.route("/index")
def index():
    #      响应体        状态码
    return "index page", 400

视图函数返回的响应还可以接受第三个参数,响应头也可以继续放在后面返回,例如:

from flask import Flask

app = Flask(__name__)


# 以元组形式返回响应信息
@app.route("/index")
def index():
    header_dict = {
        "name": "jack",
        "age": 22
    }

    header_list = [("name", "hui"), ("age", 21)]

    #      响应体        状态码    响应头
    return "index page", 400, header_dict
    # return "index page", 400, header_list

但响应头信息要用一个字典或列表包装起来,字典好理解,列表里面则是以元组形式存储响应头信息。这里返回的只是做个例子,真正返回的时候,要合理设置响应头信息,例如

header_dict = {
    "Content-Type": " text/html; charset=utf-8",   # 响应返回的数据类型
    "Set-Cookie": "name=hui; Path=/"        # 响应设置cookie
}
return "index page", 200, header_dict

浏览器开发者工具查看响应信息

Flask response响应的具体使用

切记:以元组形式返回,返回值位置不能够乱

第一个对应响应体
第二个对应状态码
第三个对应响应头

 

make_response函数

如果不想返回由1个、2个或3个值组成的元组,Flask视图函数还可以返回 Response 对象。make_response 函数可接受1个、2个或3个参数(和视图函数的返回值一样),并返回一个Response对象。看看到底如何使用

from flask import Flask, make_response

app = Flask(__name__)

# mk_response 设置响应信息
@app.route("/info")
def info():
    resp = make_response("info page")
    resp.status = "666 ithui"
    resp.headers["name"] = "hui"
    resp.headers["age"] = 21
    return resp

注意:make_response() 对象设置状态码时必须字符串,不要写成了数字

 

返回json格式数据

import json
from flask import Flask, make_response

app = Flask(__name__)


@app.route("/json")
def resp_json():
    data = {
        "name": "hui",
        "age": 21
    }

    json_str = json.dumps(data)
    headers = {"Content-Type": "application/json"}
    return json_str, 200, headers

你可以借助 json 模块进行数据 json化,但一般返回json数据要设置前端返回的数据类型,Flask默认的是text/html,因此我们还需在单独设置响应体内容类型。

由于json格式数据在Web开发中使用频繁,在 Flask 中专门提供了 jsonify() 函数进行 json数据的响应

具体使用如下

from flask import Flask, jsonify

app = Flask(__name__)


@app.route("/json")
def resp_json():
    data = {
        "name": "hui",
        "age": 21
    }
    return jsonify(data)
    # return jsonify(name="jack", age=20)

jsonify()可以接收一个字典,也可以 key-value 形式来构造 json 数据。这样就方便许多

 

其他特殊响应

 

redirect() 重定向

有一种名为重定向的特殊响应类型。这种响应类型没有页面文档,只告诉浏览器一个新地址用以加载新页面

from flask import Flask, redirect

app = Flask(__name__)

# 自己设置重定向信息
@app.route('/baidu')
def red_baidu():
    resp = make_response()
    resp.status = "302"
    resp.headers['Location'] = "http://www.baidu.com"
    return resp


# redirect 响应重定向
@app.route("/csdn")
def red_csdn():
    csdn_url = "https://blog.csdn.net/qq_43629857"
    return redirect(csdn_url)

重定向的经常使用 302 状态码表示,指向的地址由 Location 首部提供。由于使用频繁,Flask 提供了辅助函数 redirect(),用于生成这种响应。

 

abort() 中断

abort()接收一个状态码参数

from flask import Flask, request, abort

app = Flask(__name__)

# abort中断
# http://127.0.0.1:5000/login?name=hui&pwd=123
@app.route("/login", methods=['GET'])
def login():
    name = request.args.get("name")
    pwd = request.args.get("pwd")
    if name != "hui" or pwd != "123":
        abort(404)

    return "登录成功"

一般这个 abort() 函数都会配合错误信息处理装饰器 app.errorhandler() 一起使用,如下:

# 处理404状态错误
@app.errorhandler(404)
def handle_404_err(err):
    return f"404 错误信息 {err}"


# 处理500状态错误
@app.errorhandler(500)
def handle_500_err(err):
    return f"500 服务器错误 {err}"


# abort中断
# http://127.0.0.1:5000/login?name=hui&pwd=123
@app.route("/login", methods=['GET'])
def login():
    name = request.args.get("name")
    pwd = request.args.get("pwd")
    if name != "hui" or pwd != "123":
        abort(404)

    return "登录成功"

 

源代码

源代码已上传到 Gitee HuiDBK/FlaskBasic - 码云 - 开源中国 (gitee.com) ,欢迎大家来访。

到此这篇关于Flask response响应的具体使用的文章就介绍到这了,更多相关Flask response响应内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python实现搜索指定目录下文件及文件内搜索指定关键词的方法
Jun 28 Python
Python基于numpy灵活定义神经网络结构的方法
Aug 19 Python
使用python实现BLAST
Feb 12 Python
Python实现合并同一个文件夹下所有PDF文件的方法示例
Apr 28 Python
Python实现多条件筛选目标数据功能【测试可用】
Jun 13 Python
python 实现调用子文件下的模块方法
Dec 07 Python
python实现桌面气泡提示功能
Jul 29 Python
python进程间通信Queue工作过程详解
Nov 01 Python
Python3.7在anaconda里面使用IDLE编译器的步骤详解
Apr 29 Python
Django获取model中的字段名和字段的verbose_name方式
May 19 Python
使用python操作lmdb对数据读取的实例
Dec 11 Python
使用numpy nonzero 找出非0元素
May 14 Python
Python 快速验证代理IP是否有效的方法实现
Jul 15 #Python
Django路由层如何获取正确的url
Jul 15 #Python
Python实现排序方法常见的四种
Jul 15 #Python
手把手教你使用TensorFlow2实现RNN
一篇文章弄懂Python关键字、标识符和变量
python开发飞机大战游戏
详解Python中下划线的5种含义
You might like
php calender(日历)二个版本代码示例(解决2038问题)
2013/12/24 PHP
PHP中soap的用法实例
2014/10/24 PHP
PHP记录页面停留时间的方法
2016/03/30 PHP
功能强大的php文件上传类
2016/08/29 PHP
Laravel 添加多语言提示信息的方法
2019/09/29 PHP
打开超链需要“确认”对话框的方法
2007/03/08 Javascript
jQuery调用WebService的实现代码
2011/06/19 Javascript
jQuery EasyUI API 中文文档 - MenuButton菜单按钮使用介绍
2011/10/06 Javascript
js bind 函数 使用闭包保存执行上下文
2011/12/26 Javascript
JS写的贪吃蛇游戏(个人练习)
2013/07/08 Javascript
JS和jquery获取各种屏幕的宽度和高度的代码
2013/08/02 Javascript
PHP开发者必须掌握的6个关键字
2014/04/14 Javascript
JavaScript中最简洁的编码html字符串的方法
2014/10/11 Javascript
Javascript模拟加速运动与减速运动代码分享
2014/12/11 Javascript
JavaScript+CSS实现仿天猫侧边网页菜单效果
2015/08/25 Javascript
javascript性能优化之DOM交互操作实例分析
2015/12/12 Javascript
Bootstrap+jfinal实现省市级联下拉菜单
2016/05/30 Javascript
响应式表格之固定表头的简单实现
2016/08/26 Javascript
关于RequireJS的简单介绍即使用方法
2016/10/20 Javascript
利用浮层使select不可选的实现方法
2016/12/03 Javascript
js读取json文件片段中的数据实例
2017/03/09 Javascript
Vue props用法详解(小结)
2018/07/03 Javascript
Vue-Router基础学习笔记(小结)
2018/10/15 Javascript
JS localStorage存储对象,sessionStorage存储数组对象操作示例
2020/02/15 Javascript
Python编写一个闹钟功能
2017/07/11 Python
Python学习笔记之if语句的使用示例
2017/10/23 Python
Django自定义模板过滤器和标签的实现方法
2019/08/21 Python
详解向scrapy中的spider传递参数的几种方法(2种)
2020/09/28 Python
美国亚马逊旗下男装网站:East Dane(支持中文)
2019/09/25 全球购物
DeinDesign德国:设计自己的手机壳
2019/12/14 全球购物
瑞典多品牌连锁店:Johnells
2021/01/13 全球购物
工程造价与财务管理专业应届生求职信
2013/10/06 职场文书
秘书英文求职信范文
2014/01/31 职场文书
《邮票齿孔的故事》教学反思
2014/02/22 职场文书
2014年青年志愿者工作总结
2014/12/09 职场文书
JavaScript ES6的函数拓展
2022/01/18 Javascript