Flask 的 jsonify解析

Flask 的 jsonify解析首先运行如下代码:fromflaskimportFlask,jsonifyapp=Flask(__name__)tasks=[{‘id’:1,’title’:u’订阅python_mastery专栏’,’description’:u’专栏Link:https://xiaozhuanlan.com/python_mastery’},{‘id’:2,’t

大家好,又见面了,我是你们的朋友全栈君。

首先运行如下代码:

from flask import Flask, jsonify

app = Flask(__name__)

tasks = [
    { 
   
        'id': 1,
        'title': u'订阅 python_mastery 专栏',
        'description': u'专栏Link: https://xiaozhuanlan.com/python_mastery'
    },
    { 
   
        'id': 2,
        'title': u'订阅 pythonml 专栏',
        'description': u'专栏Link: https://xiaozhuanlan.com/pythonml'
    }
]

@app.route('/api/v1.0/tasks', methods=['GET'])
def get_tasks():
    return jsonify({ 
   'tasks': tasks})

if __name__ == '__main__':
    app.run(port=8888, debug=True, host='0.0.0.0')

通过请求 http://localhost:8888/api/v1.0/tasks 发现返回json数据,那为啥不用python自带的json模块返回json数据呢?

其实是一样

其实,jsonify 在处理数据过程中,对数据做 JSON 序列化处理时,用的是 itsdangerous 模块里的 JSON ,让我们看一下,这个模块里的 JSON 是如何引入的(ps:此处源码来源未找到)

try:
    import simplejson as json
except ImportError:
    import json

它会先尝试引入simplejson,如果没有安装这个模块,则引入 Python 原生模。

在Flask框架中,引入过程如下

from itsdangerous import json as _json

对于数据的序列化处理,用的正是 _json

Content-Type 的差别

前面讲到,jsonify 和 json 是殊途同归,那么为什么要费周折绕这么一圈呢?
肯定存在一个合理的原因让 jsonify存在的有意义。
这个原因就是 Content-Type
看下面两段代码

第一段代码

## jsonify
import json
from flask import Flask, jsonify

app = Flask(__name__)

@app.route('/json')
def test_json():
    data = { 
   'name': 'lilei', 'age': 30}
    return jsonify(data)

app.run(host="0.0.0.0", port=9877)

在浏览器里输入http://127.0.0.1:9877/json, 得到的结果是

{ 
   "age":30,"name":"lilei"}

第二段代码:

## json
import json
from flask import Flask, jsonify

app = Flask(__name__)

@app.route('/json')
def test_json():
    data = { 
   'name': 'lilei', 'age': 30}
    return json.dumps(data)

app.run(host="0.0.0.0", port=9877)

在浏览器里输入http://127.0.0.1:9877/json, 得到的结果是

{ 
   "name": "lilei", "age": 30}

从内容上看,两种方法没有区别。
但是使用 jsonify 时,返回的 http response 的 Content-Type 是

Content-Type: application/json

而使用json.dumps时,Content-Type则是

Content-Type: text/html; charset=utf-8

既然返回的是 json 数据,那么自然要指明 Content-Type 是 application/json , 这样做是符合 HTTP 协议的规定的,这就是使用 jsonify 的原因之一。

减小数据量

使用 jsonify 除了让返回的 http response 符合 HTTP 协议,同时也对数据做了压缩处理,让数据体积更小。

仔细比较上面两种方法返回的数据,虽然内容相同,但 jsonify 返回的数据,每个 key-value 对之间的逗号,和每个 key 与 value 之间的冒号后面都是没有空格的,而 json.dumps 返回的数据里,却在逗号和冒号后面存在空格,因此即便内容相同,jsonify 返回的数据体积更小,更节省流量。

其实,json.dumps 也可以将这些不必要的空格去掉,看下面的代码

import json

data = { 
   'name': 'lilei', 'age': 30}

print(json.dumps(data, separators=(',', ':')))
print(json.dumps(data))

输出结果为

{ 
   "name":"lilei","age":30}
{ 
   "name": "lilei", "age": 30}

只需要在 dumps 参数里指定 separators 即可,其实在 jsonify 里就是这么干的。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142278.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mac navcat15 激活码【2021.10最新】[通俗易懂]

    (mac navcat15 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~A…

    2022年3月30日
    69
  • MySql Povit_MySQL pivot row成动态列数「建议收藏」

    MySql Povit_MySQL pivot row成动态列数「建议收藏」杨魅力不幸的是,MySQL没有PIVOT基本上你想要做的功能。因此,您需要使用带有CASE语句的聚合函数:selectpt.partner_name,count(casewhenpd.product_name=’ProductA’THEN1END)ProductA,count(casewhenpd.product_name=’ProductB’THEN1…

    2025年6月20日
    2
  • win10显卡驱动怎么装_win10系统显卡驱动安装失败怎么办

    win10显卡驱动怎么装_win10系统显卡驱动安装失败怎么办大家好,今天分享一篇来自小白系统官网(xiaobaixitong.com)的图文教程。我们日常在对电脑的使用过程中,经常都会遇到这样或那样的问题。比如说win10系统显卡驱动安装失败该怎么办呢?别着急,还有小编在呢?接下来小编就来告诉大家win10电脑系统显卡驱动安装失败怎么解决。详细教你win10系统显卡驱动安装失败怎么办:方法一,删除之前的显卡驱动文件重新安装1,首先,右键点击“此电脑”,菜单…

    2022年5月26日
    36
  • excel中pmt函数是什么意思_excel利用函数计算

    excel中pmt函数是什么意思_excel利用函数计算关于PMT函数,从百科中就可以搜到基本解释:PMT函数即年金函数,基于固定利率及等额分期付款方式,返回贷款的每期付款额。PMT(Rate,Nper,Pv,Fv,Type)。语法参数●R

    2022年8月6日
    5
  • 从char 数据类型到smalldatetime 数据类型的转换导致smalldatetime 值越界

    从char 数据类型到smalldatetime 数据类型的转换导致smalldatetime 值越界
    SQL:
    select*fromdbo.pds_operation_log  where(plan_code=12andcreate_timebetween’1900-01-01’and’2098-12-31′)orderbycreate_time asc
     
    出错:
    消息296,级别16,状态3,第1行
    从char数据类型到smalldatetime数据类型的转换导致smalldatetime值越界。

    2022年5月19日
    38
  • xp的终极优化

    xp的终极优化总体设想:让WinXP更苗条、性感、速度更快,使用更便捷。为了达到这个目的,我们主要从四个方面入手:1、减少磁盘空间占用2、终止不常用的系统服务3、安全问题4、另外一些技巧首先问一下,你是不是很想激活XP,不。。。准确的说你是不是想在ms的站上能够升级。如果答案是肯定的话,那我们就先来探讨一下安装的问题,目前流行的V4、V5、V6版本我还是比较推荐的,尤其是V5和V6这两个。安装的过程中有个序

    2022年10月7日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号