Django 视图函数中的 `response` 对象及类型扩写

Django 视图函数中的 response 对象及类型扩写

在 Django 中,视图函数不仅负责处理请求,还负责生成响应。响应可以是以多种格式返回给客户端的数据,包括 HTML 页面、重定向、JSON 数据、文件等。以下是关于 Django 中几种常见响应类型的详细扩写。

HttpResponse

HttpResponse 是 Django 中最基本的响应类型,用于返回一个纯文本或 HTML 内容的响应。

python 复制代码
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")

你还可以设置响应的状态码和字符集。

python 复制代码
# 返回一个自定义状态码的响应
return HttpResponse("Not Found", status=404)

# 返回一个指定字符集的响应
return HttpResponse("Hello, World!", charset="utf-8")
render 函数

render 函数是 Django 的一个快捷函数,用于渲染一个模板并返回一个 HttpResponse 对象。

python 复制代码
from django.shortcuts import render

def my_template_view(request):
    # 传递一个字典给模板
    context = {'message': 'Hello, Template!'}
    # 渲染模板并返回响应
    return render(request, 'my_template.html', context)

模板文件 my_template.html 应该位于你配置的模板目录中,并且可以这样使用传递的上下文数据:

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <title>My Template</title>
</head>
<body>
    <h1>{{ message }}</h1>
</body>
</html>
redirect 函数 / HttpResponseRedirect

redirect 函数用于生成一个重定向响应。它会向客户端返回一个 302(临时重定向)或 301(永久重定向)状态码,以及一个新的 URL。

python 复制代码
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-Typeapplication/json

python 复制代码
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-TypeContent-Disposition 头。

python 复制代码
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)攻击,默认情况下会对所有使用 POSTPUTPATCHDELETE 等方法的表单进行 CSRF 保护。如果你的表单或 AJAX 请求遇到了 403 禁止访问的错误,通常是因为缺少了 CSRF 令牌。

  • 方式一 :在表单中添加 {% csrf_token %} 标签。
html 复制代码
<form method="post">
    {% csrf_token %}
    <!-- 表单的其他字段 -->
    <button type="submit">Submit</button>
</form>
  • 方式二 :在视图函数上使用 @csrf_exempt 装饰器来免除 CSRF 保护(不推荐,除非在特定情况下确实需要)。
python 复制代码
from django.views.decorators.csrf import csrf_exempt

@csrf_exempt
def my_exempt_view(request):
    # 处理请求
    pass
  • 方式三 :在 settings.py 中注释掉 CsrfViewMiddleware 中间件(这是非常不安全的做法,不推荐)。
python 复制代码
# MIDDLEWARE = [
#     # ...
#     'django.middleware.csrf.CsrfViewMiddleware',
#     # ...
# ]

通常,推荐使用第一种方式,即在表单中添加 {% csrf_token %} 标签,以确保 CSRF 保护的有效性。对于 AJAX 请求,你可以在发送请求时包含 CSRF 令牌,通常是通过在请求头中添加 X-CSRFToken

相关推荐
enyp8027 分钟前
qt QTreeWidget`总结
开发语言·数据库·qt
神仙别闹1 小时前
基于C#+SQL Server设计与实现的教学管理信息系统
java·数据库·c#
帅维维1 小时前
SQL*PLUS命令
数据库·sql
m0_748245521 小时前
简易图书管理系统——MYsql+Javase+JDBC
数据库·mysql
帅的飞起来2 小时前
MySQL索引失效
数据库·mysql
Joshuahgk2 小时前
MySQL 入门“鸡”础
数据库·python·mysql
_GR2 小时前
Redis存储⑫哨兵Sentinel_高可用实现方案
数据库·redis·缓存
羊小猪~~2 小时前
基于C++“简单且有效”的“数据库连接池”
java·开发语言·前端·数据库·c++·后端·adb
李少兄2 小时前
MySQL中的UNION操作符
android·数据库·mysql
Henry_Wu0013 小时前
ubuntu20.04 突破文件数限制
服务器·网络·数据库