Django---- HttpResponse响应、render 响应、redirect 响应、JsonResponse 响应

本文详细介绍了Django中HttpResponse对象的常用属性和方法,包括content、content_type和status_code。此外,还讲解了render函数的使用,如何向网页传递数据以及重定向操作,包括临时重定向和永久重定向。最后,讨论了JsonResponse在返回Json格式数据时的注意事项。通过对这些基础知识的掌握,开发者可以更好地构建Django web应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


Django 服务器启动之后, 以浏览器输入不同的路径后缀,达到访问不同的页面为例;

首先,在urls.py中,先做好路由与视图的关系

from django.conf.urls import url
from django.contrib import admin
from app01 import views as app01_views

urlpatterns = [
    url(r'^admin/', admin.site.urls),
  # 在app01 的 views.py 中写响应的函数,这里以 index 为例
    url(r'^index/',app01_views.index)
]

然后,浏览器会将提交上来的这些数据封装起来,传给对应的视图函数,视图函数在处理完相关的逻辑后,也需要返回一个响应给浏览器

app01.views.py文件

注意:所有的视图函数都需要一个位置参数,这个参数就是请求相关的所有数据对象

from django.shortcuts import render, HttpResponse, redirect


def index(request):
    """
    :param request:
    :return:
    """
    return '响应对象'

一、HttpResponse介绍

1.1 常用属性

content:返回的内容

也可以在HttpResponse()的括号内直接写

from django.shortcuts import render, HttpResponse, redirect

def index(request):
    response = HttpResponse()
    response.content='<h1>6666</h1>'

    return response

或者

from django.shortcuts import render, HttpResponse, redirect

def index(request):
    response = HttpResponse('<h1>6666</h1>')

    return response

在这里插入图片描述

content_type:返回的数据的MIME类型

默认为text/html。浏览器会根据这个属性,来显示数据。如果是text/html,那么就会解析这个字符串,如果text/plain,那么就会显示一个纯文本。常用的Content-Type如下:

text/html(默认的,html文件)
text/plain(纯文本)注意: 一般在使用‘text/plain’时,都会添加‘charset=utf-8’,否则是会乱码的。
text/css(css文件)
text/javascript(js文件)
multipart/form-data(文件提交)
application/json(json传输)
application/xml(xml文件)

from django.shortcuts import render, HttpResponse, redirect

def index(request):
    response = HttpResponse('<h1>6666</h1>',content_type='text/plain;charset=utf-8')
    
    return response

在这里插入图片描述

status_code: 返回的HTTP响应状态码

默认是200,也可以自行设置
 
 

1.2 常用方法

  1. set_cookie:用来设置cookie信息
  2. delete_cookie:用来删除cookie信息。
  3. write:HttpResponse是一个类似于文件的对象,可以用来写入数据到数据体(content)中
def index(request):
    response = HttpResponse('<h1>66666</h1>')
    response.write('zzzzzzzz')
    return response

在这里插入图片描述

二、render:返回网页

在这里插入图片描述
观察源码发现,render其实也是一个HttpResponse对象, 结合一个给定的模板和一个给定的上下文字典,并返回一个渲染后的 HttpResponse 对象。

参数说明

request: 用于生成响应的请求对象。

template_name:要使用的模板的完整名称,可选的参数

context:添加到模板上下文的一个字典。默认是一个空字典。如果字典中的某个值是可调用的,视图将在渲染模板之前调用它。

content_type:生成的文档要使用的MIME类型。默认为 DEFAULT_CONTENT_TYPE 设置的值。默认为’text/html’

status:响应的状态码。默认为200。

useing: 用于加载模板的模板引擎的名称。

template文件夹加入配置之后,输入网页文件的名称时,会自动查找并提醒!

from django.shortcuts import render, HttpResponse, redirect

def index(request):
    response = render(request,'render_test.html')

    return response

2.1 给网页传值

方式一:指名道姓传几个参数

render ( request, ‘网页’, {‘字段 1’: 值,‘字段 2’:值} )

views.py文件中

from django.shortcuts import render, HttpResponse, redirect

def index(request):
  	user_dict = {'name':'frank','age':18}
    response = render(request,'render_test.html', {'data':user_dict,'date':123})

    return response

render_test.html通过{{ 字段 }}拿值

<body>
    <div>data:{{ data }}</div>
    <div>date:{{ date }}</div>
</body>

在这里插入图片描述

方式二:使用locals()将函数内部所有的变量名都传给网页,包括request

from django.shortcuts import render, HttpResponse, redirect

def index(request):
  	user_dict = {'name':'frank','age':18}
    response = render(request,'render_test.html', locals())

    return response

三、redirect:重定向

观察源码发现,redirect其实也是一个HttpResponse对象
参数可以是:

  • 一个模型:将调用模型的get_absolute_url() 函数
  • 一个视图,可以带有参数:将使用urlresolvers.reverse 来反向解析名称
  • 一个绝对的或相对的URL,将原封不动的作为重定向的位置。

默认返回一个临时的重定向;传递permanent=True 可以返回一个永久的重定向。


示例:

传递一个具体的ORM对象(了解即可)

将调用具体ORM对象的get_absolute_url() 方法来获取重定向的URL:

from django.shortcuts import redirect
 
def my_view(request):
    ...
    object = MyModel.objects.get(...)
    return redirect(object)

 

传递一个视图的名称

def my_view(request):
    ...
    return redirect('some-view-name', foo='bar')

 

跳转其他网址

写全地址名

from django.shortcuts import render, HttpResponse, redirect

def index(request):
    response = redirect('https://www.baidu.com/')

    return response

在这里插入图片描述

只写后缀,则跳转的是该项目下的其他功能页面

urls.py

from django.conf.urls import url
from django.contrib import admin
from app01 import views as app01_views

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'index/',app01_views.index),
    url(r'home/',app01_views.home),
]

views.py

from django.shortcuts import render, HttpResponse, redirect
def index(request):
    response = redirect('/home/')

    return response


def home(request):
    return render(request,'render_test.html')

在这里插入图片描述


 

默认情况下,redirect() 返回一个临时重定向。以上所有的形式都接收一个permanent 参数;如果设置为True,将返回一个永久的重定向:

def my_view(request):
    ...
    object = MyModel.objects.get(...)
    return redirect(object, permanent=True)  

扩展阅读:

临时重定向(响应状态码:302)和永久重定向(响应状态码:301)对普通用户来说是没什么区别的,它主要面向的是搜索引擎的机器人。

A页面临时重定向到B页面,那搜索引擎收录的就是A页面。

A页面永久重定向到B页面,那搜索引擎收录的就是B页面。


 

四、JsonResponse: 返回 Json 格式数据

如果想要将json格式的数据,通过HttpResponse返回给前端

from django.shortcuts import HttpResponse
import json

def json_data(request):
  dict_data = {'username':'大傻蛋_1', 'pwd':'123'}
  # 序列化
  json_data = json.dumps(dict_data)
  
  return HttpResponse(json_data)

会发现在前端页面中,中文的部分是被二进制的数据代替了,并没有展示中文

那么此时,需要修改dumps方法的一个参数ensure_ascii=False

from django.shortcuts import HttpResponse
import json

def json_data(request):
  dict_data = {'username':'大傻蛋_1', 'pwd':'123'}
  # 序列化
  json_data = json.dumps(dict_data, ensure_ascii=False)
  
  return HttpResponse(json_data)

而 JsonResponse 其本质就是将数据自动序列化,然后通过 HttpResponse 响应返回

注意:该方法导入的模块是django.http

from django.http import JsonResponse

def json_data(request):
  dict_data = {'username':'大傻蛋_1', 'pwd':'123'}
  
  return JsonResponse(dict_data)

会发现在前端页面中,中文的部分是被二进制的数据代替了,并没有展示中文

在这里插入图片描述

观察其源码会发现,其实底层原理就是调用了dumps方法,那么只需要传入一个json_dumps_params{ 'ensure_ascii': False }

from django.http import JsonResponse

def json_data(request):
  dict_data = {'username':'大傻蛋_1', 'pwd':'123'}
  
  return JsonResponse(dict_data, json_dumps_params{ 'ensure_ascii': False })

此时前端页面中的中文格式的数据,就能正常展示了


对于非字典类型的数据进行 JSON 序列化时,需要修改一个safe=False参数

from django.http import JsonResponse

def json_data(request):
  data = [11,22,33,44]
  
  return JsonResponse(data, safe=False)
<think>我们正在讨论Django视图函数的返回类型。用户的问题核心是:Django视图函数是否必须返回HttpResponse对象?是否存在其他可接受的返回类型? 根据提供的引用,我们可以总结如下: 1. 引用[1]指出:HttpResponse对象是由开发人员创建,用于响应用户访问。并且提到可以通过向构造函数传递网页内容来构造HttpResponse实例。 2. 引用[2]提到:视图函数返回值包括HTML响应JsonResponse,并且还提到了HttpResponseRedirect(它继承自HttpResponseRedirectBase,而HttpResponseRedirectBase又继承自HttpResponse)。 3. 引用[3]列举了三种返回类型:HttpResponse(直接返回字符串)、render(渲染模板并返回)、JsonResponse返回json类型)。并且明确指出这些返回对象都是HttpResponse对象或其子类。 4. 引用[4]展示了一个视图函数,它返回一个HttpResponse对象。 然而,用户提到“必须返回HttpResponse对象”的说法可能有错误,我们需要指出是否存在其他可接受的返回类型。 实际上,在Django中,视图函数可以返回以下类型: - HttpResponse对象(包括其子类,如HttpResponseRedirect, JsonResponse, HttpResponseNotFound等) - 也可以返回一个字典(结合render函数使用,但注意render函数返回的也是HttpResponse对象) - 另外,Django还支持返回一个字符串(但通常不直接返回字符串,而是包装在HttpResponse中) 但是,从严格意义上讲,视图函数必须返回一个HttpResponse对象。因为Django框架要求视图函数返回一个HttpResponse对象,以便框架能够处理HTTP响应。 然而,我们注意到Django REST框架(如果使用的话)可能允许返回其他类型,但这是扩展框架。在纯Django视图函数中,返回类型必须是HttpResponse对象或其子类。 但是,我们也可以参考Django官方文档,它指出视图函数可以返回- 一个HttpResponse对象。 - 或者抛出一个异常(如Http404)。 另外,从Django 1.3开始,视图函数还可以返回一个可迭代对象(如生成器)或者一个字符串(但Django会将其包装成HttpResponse对象?)。实际上,Django内部会确保最终返回的是一个HttpResponse对象。 但是,我们注意到在Django 2.0之后,视图函数还可以返回一个`HttpResponse`的子类,或者一个`django.template.response.TemplateResponse`对象。而`TemplateResponse`对象在最终渲染时会变成HttpResponse对象。 因此,准确地说,视图函数必须返回一个HttpResponse对象(包括其子类)或者一个TemplateResponse对象(它虽然不是HttpResponse的子类,但Django框架能够处理它,并在最后将其渲染为HttpResponse对象)。此外,还可以返回一个满足WSGI协议的可调用对象(但通常不常见)。 然而,根据引用[3]中的内容,我们注意到render函数返回的也是一个HttpResponse对象(实际上,render函数返回的是HttpResponse的一个子类实例)。而JsonResponse也是HttpResponse的子类。 所以,用户的问题中提到的“必须返回HttpResponse对象”这一说法并不完全错误,但是需要扩展:除了HttpResponse对象及其子类外,还可以返回TemplateResponse对象(它不是一个HttpResponse对象,但Django会处理它)。此外,还可以返回一个重定向的快捷方式(如`redirect`函数,它返回的是HttpResponseRedirect,即HttpResponse的子类)。 因此,我们可以这样回答: - Django视图函数的主要要求是返回一个HttpResponse对象(或其子类)的对象。 - 但是,也可以返回一个TemplateResponse对象,它允许在响应处理过程中延迟渲染。 - 另外,还可以返回一个HttpResponse的子类对象,如JsonResponse, HttpResponseRedirect等。 - 如果视图函数返回的不是这些对象,Django会尝试将其转换为HttpResponse对象(例如,如果返回一个字符串,Django会将其包装为一个HttpResponse对象,但这不是推荐的做法,并且在一些Django版本中可能不支持直接返回字符串)。 然而,根据最新的Django文档(3.2),视图函数必须返回一个HttpResponse对象或者一个异常。但是,实际上,在Django中,我们常用的快捷函数(如render, redirect返回的都是HttpResponse对象或其子类。 但是,我们注意到在引用[2]中提到了视图函数返回值可以是HTML响应(即通过render返回HttpResponse)和JsonResponse(也是HttpResponse的子类),以及反向解析中使用的HttpResponseRedirect(重定向)。 因此,结论是:视图函数必须返回一个HttpResponse对象(包括其子类)或者一个TemplateResponse对象(它是可接受的,因为最终会被处理成HttpResponse)。另外,抛出异常也是一种方式(但不是返回,而是中断视图)。 所以,严格来说,视图函数必须返回一个HttpResponse对象(或其子类)或者一个TemplateResponse对象。但是,我们通常所说的返回类型都是HttpResponse对象或其子类,因为TemplateResponse也是被设计为在中间件处理过程中最终被渲染成HttpResponse。 因此,用户提到的“必须返回HttpResponse对象”这一说法在大多数情况下是正确的,但存在例外(TemplateResponse)。另外,快捷函数返回的也是HttpResponse的子类。 现在,我们可以组织答案: 答案: 在Django中,视图函数通常必须返回一个HttpResponse对象或其子类的实例。这是因为Django框架需要处理HTTP响应,而HttpResponse对象封装了HTTP响应的内容、状态码和响应头。 但是,除了HttpResponse及其子类之外,Django还允许返回以下类型: 1. `django.template.response.TemplateResponse`对象:它不是一个HttpResponse对象,但它是一个延迟渲染的响应对象。在视图处理完成后,Django会在响应处理过程中将其转换为HttpResponse对象。 2. 重定向对象:通过`redirect()`函数返回的对象实际上是HttpResponseRedirect(它是HttpResponse的子类)的实例。 另外,视图函数也可以返回一个字符串,但这不是推荐的方式,并且在较新的Django版本中可能不再支持。在旧版本中,Django可能会自动将字符串包装为HttpResponse,但最好显式地返回HttpResponse。 常见的返回方式包括: - `HttpResponse(content)`:直接返回一个字符串内容。 - `render(request, template_name, context)`:渲染模板并返回一个HttpResponse对象(实际上是HttpResponse的子类)。 - `JsonResponse(data)`:返回JSON格式的响应- `redirect(to)`:返回一个重定向响应HttpResponseRedirect)。 所以,虽然视图函数必须返回一个HttpResponse对象(或其子类)或者TemplateResponse对象,但我们在编写视图时通常使用快捷函数(如render, redirect等)来返回,这些函数返回的都是HttpResponse的子类或TemplateResponse。 因此,关于“必须返回HttpResponse对象”的说法,严格来说,视图函数可以返回HttpResponse对象、HttpResponse子类对象、TemplateResponse对象。所以,这个说法并不完全错误,但也不全面。 参考文献: [^1]: 引用[1]提到HttpResponse对象是由开发人员创建,并且是响应的基础。 [^2]: 引用[2]提到了视图函数返回值包括重定向(HttpResponseRedirect)和JsonResponse等。 [^3]: 引用[3]提到了HttpResponserender返回渲染后的HttpResponse)和JsonResponse。 因此,我们可以总结:视图函数必须返回一个HttpResponse对象(或其子类)或者一个TemplateResponse对象(它最终会被转换为HttpResponse对象)。 现在,生成相关问题: 1. Django中TemplateResponse和HttpResponse有什么区别? 2. 如何在Django视图函数中返回JSON数据? 3. 重定向在Django中如何实现? 4. Django视图函数可以返回一个字典吗?如果不能,为什么? 5. 在Django中,如何处理视图函数返回的非HttpResponse对象? 注意:最后一个问题(问题4)的答案是:不能直接返回字典。因为Django要求返回HttpResponse对象或其子类或TemplateResponse。如果返回字典,Django会抛出异常。但是,如果使用Django REST框架,则视图可以返回字典,因为REST框架会将其转换为JSON响应。在普通Django视图中,要返回JSON,应该使用JsonResponse。</think>### Django视图函数的返回类型要求 在Django中,视图函数**不必强制返回`HttpResponse`对象本身**,但必须返回一个**可被Django框架转换为`HttpResponse`对象的响应类型**。以下是完整的返回类型分类: #### ✅ 允许的返回类型 1. **`HttpResponse`及其子类**(核心要求) Django响应对象体系均继承自`HttpResponse`基类[^1][^3],包括: - 基础响应:`HttpResponse(content="文本内容")` - 重定向:`HttpResponseRedirect`(302状态码)[^2] - JSON响应:`JsonResponse({"key": "value"})`[^3] - 文件响应:`FileResponse` 2. **渲染模板的快捷方式** `render()`函数返回的仍是`HttpResponse`子类对象[^3]: ```python return render(request, 'template.html', {'data': value}) # 本质是HttpResponse ``` 3. **`TemplateResponse`(延迟渲染对象)** 特殊的高级响应类型,允许中间件修改内容,最终会被Django自动转换为`HttpResponse`[^3]。 #### ❌ 不允许的返回类型 - 原生Python类型(如字符串、字典、列表) 直接返回`"Hello"`或`{"status": "ok"}`会引发`TypeError`,因为Django无法处理非响应对象。 - 其他框架的对象(如Flask的Response) #### 🔄 自动转换机制 Django会对某些特殊类型做隐式转换: - 返回`None`时,自动转为空`HttpResponse`(状态码200) - 旧版Django(<3.0)允许返回字符串(自动包装为`HttpResponse`),但**新版已废弃此行为**。 ### 错误说法澄清 > “视图函数必须返回HttpResponse对象” > **错误点**:忽略了合法的非`HttpResponse`类型 > **正确表述**: > 视图函数必须返回`HttpResponse`对象、其子类对象、或可被Django转换为`HttpResponse`的对象(如`TemplateResponse`)[^1][^2][^3]。 --- ### 示例对比 ```python # ✅ 合法 def valid_view(request): return HttpResponse("文本") # 直接返回HttpResponse # ✅ 合法(子类) def json_view(request): return JsonResponse({"code": 200}) # HttpResponse子类 # ✅ 合法(快捷方式) def template_view(request): return render(request, 'app/page.html') # 返回HttpResponse子类 # ❌ 非法 def invalid_view(request): return "直接字符串" # 触发TypeError ``` ### 核心结论 Django视图函数**不强制返回原始`HttpResponse`对象**,但必须返回: 1. `HttpResponse`实例或其子类 2. `TemplateResponse`实例 3. 被Django中间件支持的可转换类型 这确保了Django的请求-响应循环能正确处理HTTP协议[^1][^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值