Django 视图函数中的 response
对象及类型扩写
在 Django 中,视图函数不仅负责处理请求,还负责生成响应。响应可以是以多种格式返回给客户端的数据,包括 HTML 页面、重定向、JSON 数据、文件等。以下是关于 Django 中几种常见响应类型的详细扩写。
HttpResponse
HttpResponse
是 Django 中最基本的响应类型,用于返回一个纯文本或 HTML 内容的响应。
from django.http import HttpResponse
def my_view(request):
# 返回一个简单的文本响应
return HttpResponse("Hello, World!")
# 返回一个 HTML 内容的响应
# html_content = "<html><body><h1>Hello, World!</h1></body></html>"
# return HttpResponse(html_content, content_type="text/html")
你还可以设置响应的状态码和字符集。
# 返回一个自定义状态码的响应
return HttpResponse("Not Found", status=404)
# 返回一个指定字符集的响应
return HttpResponse("Hello, World!", charset="utf-8")
render 函数
render
函数是 Django 的一个快捷函数,用于渲染一个模板并返回一个 HttpResponse
对象。
from django.shortcuts import render
def my_template_view(request):
# 传递一个字典给模板
context = {'message': 'Hello, Template!'}
# 渲染模板并返回响应
return render(request, 'my_template.html', context)
模板文件 my_template.html
应该位于你配置的模板目录中,并且可以这样使用传递的上下文数据:
<!DOCTYPE html>
<html>
<head>
<title>My Template</title>
</head>
<body>
<h1>{{ message }}</h1>
</body>
</html>
redirect 函数 / HttpResponseRedirect
redirect
函数用于生成一个重定向响应。它会向客户端返回一个 302(临时重定向)或 301(永久重定向)状态码,以及一个新的 URL。
from django.shortcuts import redirect
def my_redirect_view(request):
# 重定向到一个新的 URL
return redirect('/new-url/')
# 使用命名 URL 模式重定向,并传递参数
# return redirect('named_url_pattern', arg1=value1, arg2=value2)
# 永久重定向
# return redirect('/new-url/', permanent=True)
JsonResponse
JsonResponse
用于返回 JSON 格式的响应。它自动设置 Content-Type
为 application/json
。
from django.http import JsonResponse
def my_json_view(request):
data = {'message': 'Hello, JSON!'}
return JsonResponse(data)
# 如果需要自定义 JSON 序列化行为,可以传递 encoder 参数
# from django.core.serializers.json import DjangoJSONEncoder
# class MyEncoder(DjangoJSONEncoder):
# # 自定义序列化行为
# pass
# return JsonResponse(data, encoder=MyEncoder)
# 如果需要返回非字典类型的数据,可以将 safe 设置为 False
# data = ['Hello', 'World']
# return JsonResponse(data, safe=False)
FileResponse
FileResponse
用于返回文件内容的响应。它接受一个文件对象或文件路径,并自动设置适当的 Content-Type
和 Content-Disposition
头。
from django.http import FileResponse
import os
def my_file_view(request):
# 假设文件位于项目的 media 目录下
file_path = os.path.join(BASE_DIR, 'media', 'myfile.txt')
# 打开文件并创建 FileResponse
with open(file_path, 'rb') as file:
response = FileResponse(file)
# 可以设置 Content-Disposition 为 attachment 以提示浏览器下载文件
# response['Content-Disposition'] = 'attachment; filename="myfile.txt"'
return response
POST 提交 403 禁止访问 的解决方案
在 Django 中,为了防止跨站请求伪造(CSRF)攻击,默认情况下会对所有使用 POST
、PUT
、PATCH
、DELETE
等方法的表单进行 CSRF 保护。如果你的表单或 AJAX 请求遇到了 403 禁止访问的错误,通常是因为缺少了 CSRF 令牌。
- 方式一:在表单中添加
{% csrf_token %}
标签。
<form method="post">
{% csrf_token %}
<!-- 表单的其他字段 -->
<button type="submit">Submit</button>
</form>
- 方式二:在视图函数上使用
@csrf_exempt
装饰器来免除 CSRF 保护(不推荐,除非在特定情况下确实需要)。
from django.views.decorators.csrf import csrf_exempt
@csrf_exempt
def my_exempt_view(request):
# 处理请求
pass
- 方式三:在
settings.py
中注释掉CsrfViewMiddleware
中间件(这是非常不安全的做法,不推荐)。
# MIDDLEWARE = [
# # ...
# 'django.middleware.csrf.CsrfViewMiddleware',
# # ...
# ]
通常,推荐使用第一种方式,即在表单中添加 {% csrf_token %}
标签,以确保 CSRF 保护的有效性。对于 AJAX 请求,你可以在发送请求时包含 CSRF 令牌,通常是通过在请求头中添加 X-CSRFToken
。