Backend - Django JsonResponse HttpResponse

2023-12-12 04:01

本文主要是介绍Backend - Django JsonResponse HttpResponse,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、关系

二、使用

(一)data 字典传值

1. HttpResponse

(1)写法

(2)前端接收 HttpResponse 回传的值

2. JsonResponse

(1)写法

(2)前端接收 JsonResponse 回传的值

3. 特殊数据类型的处理

4. 例子

(二)JsonResponse 有一个 safe 参数

1. safe 作用

2. 若报错:TypeError: In order to allow non-dict objects to be serialized set the safe parameter to False

(1)原因

(2)解决


一、关系

        JsonResponse 是 HttpResponse 的一个子类。

        从1.7版本开始,Django使用内置JsonResponse类。

二、使用

(一)data 字典传值

1. HttpResponse

(1)写法

HttpResponse 的 content 参数值必须是引号包裹的字符串。

比如,若 data 参数值是个对象(字典),则用 json.dumps 将 data 值转成JSON字串。

# HttpResponse
import json
return HttpResponse(json.dumps(mydict))
(2)前端接收 HttpResponse 回传的值

因为,HttpResponse传的值是通过json处理后的字串格式。所以,前端ajax收到的data是json字串格式,需要用JSON.parse(data)处理,去除json字串。

2. JsonResponse

(1)写法

JsonResponse 的 data 参数可以是个对象(字典)。

# JsonResponse
from django.http import JsonResponse
return JsonResponse(mydict)
(2)前端接收 JsonResponse 回传的值

因为,JsonResponse传的值是字典,没有经过json处理。所以,前端可以不用JSON.parse(data)处理,直接使用。

3. 特殊数据类型的处理

        若是queryset类型的列表,可以先利用列表生成式转换成阵列,再传给前端。

# JsonResponse
from django.http import JsonResponse
myqst = models.Book.objects.filter(booktype='文艺类').values_list('name', flat=True)
mylist = [m for m in myqst]
return JsonResponse(mylist)

4. 例子

import json
from django.http import JsonResponse
data= {'name': '萝卜干'}# 第一种
HttpResponse(json.dumps(data), content_type='application/json')  # 第一个参数位置,默认是content的参数值,第二个位置需要指定是什么参数的值,比如content_type=XXX# 第二种(几乎等价于第一种)
JsonResponse(data)  # 默认的content_type='application/json'

 json相关知识可参考另一篇文章:Backend - Python 序列化-CSDN博客

(二)JsonResponse 有一个 safe 参数

1. safe 作用

        默认为 True,控制JsonResponse中只有dict对象可以序列化。

2. 若报错:TypeError: In order to allow non-dict objects to be serialized set the safe parameter to False

(1)原因

        JsonResponse中的safe参数为True,要求data值类型必须为字典,若非字典则抛出一个 TypeError 类型错误。  

(2)解决

        方法① 传data参数为字典类型。

        方法② 若想传列表List类型等,则设置参数safe=False。如下面代码:

return JsonResponse(result)
# 改为:
return JsonResponse(result, safe=False)

这篇关于Backend - Django JsonResponse HttpResponse的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/483163

相关文章

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

利用Django框架快速构建Web应用:从零到上线

随着互联网的发展,Web应用的需求日益增长,而Django作为一个高级的Python Web框架,以其强大的功能和灵活的架构,成为了众多开发者的选择。本文将指导你如何从零开始使用Django框架构建一个简单的Web应用,并将其部署到线上,让世界看到你的作品。 Django简介 Django是由Adrian Holovaty和Simon Willison于2005年开发的一个开源框架,旨在简

Linux搭建Python3、Django环境

开发十年,就只剩下这套架构体系了! >>>    好久没写了,朋友们,我又回来了。 安装Python3 Python全部版本下载地址:         https://www.python.org/ftp/ 解决RedHat,使用Python3退格出现乱码问题:         yum -y install readline-devel.x86_64 下载Python3:

Django 第十七课 -- 视图 - FBV 与 CBV

目录 一. 前言 二. FBV 三. CBV 一. 前言 FBV(function base views) 基于函数的视图,就是在视图里使用函数处理请求。 CBV(class base views) 基于类的视图,就是在视图里使用类处理请求。 二. FBV 基于函数的视图其实我们前面章节一直在使用,就是使用了函数来处理用户的请求,查看以下实例: 路由配置: urlpat

django摄影竞赛小程序论文源码调试讲解

2系统关键技术及工具简介 系统开发过程中设计的关键技术是系统的核心,而开发工具则会影响的项目开发的进程和效率。第二部分便描述了系统的设计与实现等相关开发工具。 2.1 Python简介 Python 属于一个高层次的脚本语言,以解释性,编译性,互动性和面向对象相结合。在设计上相比其他语言,它更具有特色语法结构,很强的可读性。 2.2 Django框架 Django是一个开放源

Django 测试指南

#Django 测试指南 对绝大部分人来说,测试Django应用感觉很神秘,他们只是听说代码必须要测试,但是经常找不到线索如何入手。当他们看了Django的测试文档,他们找到深入的哪些功能是可用的,但是如果实现没有任何指导。 这是本博客系列的第一篇,尝试帮助大家减轻压力,使得每个人在测试潮流。假设你从来没有做过任何测试,但是对Python&Django很熟悉了。 我们将贯穿添加测试到pere

使用django-simple-captcha遇到的坑

使用django-simple-captcha遇到的坑 一站点gongshare.com在做注册功能时验证码采用的django-simple-captcha,因为笔者开发环境采用的Windows 64bit系统,结果安装使用的时候接二连三遇到好几个坑。 django-simple-captcha需要依赖django1.3+、PIL1.1.7+或者Pillow2.0+,根据文档安装后开始使用时,

解决Django会话中的竞态条件

Django 会话中的竞态条件(race condition)问题通常发生在多个请求几乎同时修改同一个会话数据时,导致数据丢失或数据不一致。这种情况在需要频繁更新会话数据的场景(如实时聊天应用、并发请求处理等)中尤为常见。 1、问题背景 在 Django 中使用会话时,可能会遇到竞态条件,导致数据丢失或不一致。竞态条件是指两个或多个请求同时访问共享资源时,由于执行顺序的不确定性,导致数据不

Django+Vue3前后端分离学习(五)(前端登录页面搭建)

1、如果需要使用组合式API,需要安装插件: npm install vite-plugin-vue-setup-extend --save-dev 在vite.config.js里配置: 首先导入: import VueSetupExtend from 'vite-plugin-vue-setup-extend' 添加: 2、创建login.vue 然后再index.js里添加

Python——在Linux和Windows下创建Django项目

前言:我和一个室友合作写了一个网站,“网络数据库技术”的课程 project。 从2016年4月8日开始,到2016年4月29日发布第一个版本,在这三个星期的时间里面,前一半时间用来学习Python,Django和Git/GitHub,后一半时间现学现卖,真正在写网站。期间充满了对于未知的探索,在短时间内增加了很多新技能,对整个互联网有了更深的认识。 这个 web project 发布在G