跳至主要內容

Rest-framework专栏讲解(二十八): settings

Mr.暴走の海鸽约 5906 字大约 20 分钟

Rest-framework专栏讲解(二十八): settings

目录

官方原文链接open in new window

Settingsopen in new window

Namespaces are one honking great idea - let's do more of those! — [The Zen of Python][cite]

REST framework 的配置是在名为 REST_FRAMEWORK 的单个 Django 设置中的所有命名空间。

例如,你的项目的 settings.py 文件可能包含如下所示的内容:

REST_FRAMEWORK = {
    'DEFAULT_RENDERER_CLASSES': (
        'rest_framework.renderers.JSONRenderer',
    ),
    'DEFAULT_PARSER_CLASSES': (
        'rest_framework.parsers.JSONParser',
    )
}

访问 settingsopen in new window

如果你需要访问项目中 REST framework 的 API 设置值,则应使用 api_settings 对象。例如。

from rest_framework.settings import api_settings

print api_settings.DEFAULT_AUTHENTICATION_CLASSES

api_settings 对象将检查用户定义的设置,否则将回退到默认值。任何使用字符串导入路径引用类的设置都会自动导入并返回被引用的类,而不是字符串文字。


API 参考open in new window

API 策略设置open in new window

以下设置控制基本 API 策略,并应用于每个基于 APIView 类的视图或基于 @api_view 函数的视图。

DEFAULT_RENDERER_CLASSESopen in new window

渲染器类的列表或元组,用于确定返回 Response 对象时可能使用的默认渲染器集。

默认值:

(
    'rest_framework.renderers.JSONRenderer',
    'rest_framework.renderers.BrowsableAPIRenderer',
)

DEFAULT_PARSER_CLASSESopen in new window

解析器类的列表或元组,用于确定访问 request.data 属性时使用的默认解析器集。

默认值:

(
    'rest_framework.parsers.JSONParser',
    'rest_framework.parsers.FormParser',
    'rest_framework.parsers.MultiPartParser'
)

DEFAULT_AUTHENTICATION_CLASSESopen in new window

身份验证类的列表或元组,用于确定在访问 request.userrequest.auth 属性时使用的默认身份验证集。

默认值:

(
    'rest_framework.authentication.SessionAuthentication',
    'rest_framework.authentication.BasicAuthentication'
)

DEFAULT_PERMISSION_CLASSESopen in new window

权限类的列表或元组,用于确定在视图开始时检查的默认权限集。权限必须由列表中的每个类授予。

默认值:

(
    'rest_framework.permissions.AllowAny',
)

DEFAULT_THROTTLE_CLASSESopen in new window

限流类的列表或元组,用于确定在视图开始时检查的默认限流类集。

默认值: ()

DEFAULT_CONTENT_NEGOTIATION_CLASSopen in new window

内容协商类,用于确定如何为响应选择渲染器,并给定传入请求。

默认值:'rest_framework.negotiation.DefaultContentNegotiation'

DEFAULT_SCHEMA_CLASSopen in new window

将用于 schema 生成的视图检查类。

默认值:'rest_framework.schemas.AutoSchema'


Generic view settingsopen in new window

以下设置控制通用基于类的视图的行为。

DEFAULT_FILTER_BACKENDSopen in new window

用于通用过滤的过滤器后端类列表。如果设置为 None,则禁用通用过滤。

PAGE_SIZEopen in new window

用于分页的默认页面大小。如果设置为 None,则默认情况下禁用分页。

默认值:None

SEARCH_PARAMopen in new window

查询参数的名称,可用于指定 SearchFilter 使用的搜索词。

默认值:search

ORDERING_PARAMopen in new window

排序参数的名称,可用于指定 OrderingFilter 返回结果的排序。

默认值:ordering


版本控制设置open in new window

DEFAULT_VERSIONopen in new window

当没有版本信息存在时,默认的 request.version 值。

默认值:None

ALLOWED_VERSIONSopen in new window

如果设置,则此值将限制版本控制方案可能返回的版本集合,如果提供的版本不在此集合中,则会引发错误。

默认值:None

VERSION_PARAMopen in new window

用于版本控制参数的字符串,例如媒体类型或 URL 查询参数。

默认值:'version'


认证设置open in new window

以下设置控制未经身份验证的请求的行为。

UNAUTHENTICATED_USERopen in new window

用于初始化未经身份验证的请求的 request.user的类。(如果要完全删除验证,可以通过从 INSTALLED_APPS 中除去 django.contrib.auth,将 UNAUTHENTICATED_USER 设置为 None。)

默认值: django.contrib.auth.models.AnonymousUser

UNAUTHENTICATED_TOKENopen in new window

用于初始化未经身份验证的请求的 request.auth 的类。

默认值:None


测试设置open in new window

以下设置控制 APIRequestFactory 和 APIClient 的行为

TEST_REQUEST_DEFAULT_FORMATopen in new window

进行测试请求时应使用的默认格式。

这应该与 TEST_REQUEST_RENDERER_CLASSES 设置中的其中一个渲染器类的格式相匹配。

默认值: 'multipart'

TEST_REQUEST_RENDERER_CLASSESopen in new window

构建测试请求时支持的渲染器类。

构建测试请求时可以使用任何这些渲染器类的格式,例如:client.post('/users', {'username': 'jamie'}, format='json')

默认值:

(
    'rest_framework.renderers.MultiPartRenderer',
    'rest_framework.renderers.JSONRenderer'
)

Schema 生成控制open in new window

SCHEMA_COERCE_PATH_PKopen in new window

如果设置,则在生成 schema 路径参数时,会将 URL conf 中的 'pk' 标识符映射到实际字段名称上。通常这将是 'id' 。由于 “primary key” 是实现细节,因此这提供了更适合的表示,而 “identifier” 是更一般的概念。

默认值:True

SCHEMA_COERCE_METHOD_NAMESopen in new window

如果设置,则用于将内部视图方法名称映射到 schema 生成中使用的外部操作名称。这使我们能够生成比代码库中内部使用的名称更适合外部表示的名称。

默认值: {'retrieve': 'read', 'destroy': 'delete'}


内容类型控制open in new window

URL_FORMAT_OVERRIDEopen in new window

通过在请求 URL 中使用 format=… 查询参数,可用于覆盖默认内容协商 Accept header 行为的 URL 参数的名称。

例如: http://example.com/organizations/?format=csv

如果此设置的值为 None,则 URL 格式覆盖将被禁用。

默认值: 'format'

FORMAT_SUFFIX_KWARGopen in new window

URL conf 中用于提供格式后缀的参数名称。使用 format_suffix_patterns 包含后缀 URL patterns 时应用此设置。

例如:http://example.com/organizations.csv/

默认值:'format'


日期和时间格式open in new window

以下设置用于控制如何分析和渲染日期和时间表示。

DATETIME_FORMATopen in new window

格式字符串,默认情况下用于渲染 DateTimeField 序列化字段的输出。如果为 None,那么 DateTimeField 序列化字段将返回 Python datetime 对象,并且日期时间编码将由渲染器决定。

可以是 None'iso-8601' 或 Python strftime 格式字符串中的任何一个。

默认值:'iso-8601'

DATETIME_INPUT_FORMATSopen in new window

默认使用的格式字符串列表,用于解析 DateTimeField 序列化字段的输入。

可以是包含字符串 'iso-8601' 或 Python strftime 格式字符串的列表。

默认值: ['iso-8601']

DATE_FORMATopen in new window

格式字符串,默认情况下用于渲染 DateField 序列化字段的输出。如果为 None,那么 DateField 序列化字段将返回 Python date 对象,并且日期编码将由渲染器决定。

可以是 None'iso-8601' 或 Python strftime 格式字符串中的任何一个。

默认值:'iso-8601'

DATE_INPUT_FORMATSopen in new window

默认使用的格式字符串列表,用于解析 DateField 序列化字段的输入。

可以是包含字符串 'iso-8601' 或 Python strftime 格式字符串的列表。

默认值:['iso-8601']

TIME_FORMATopen in new window

格式字符串,默认情况下用于渲染 imeField 序列化字段的输出。如果为 None,那么 TimeField 序列化字段将返回 Python time 对象,并且时间编码将由渲染器决定。

可以是 None'iso-8601' 或 Python strftime 格式字符串中的任何一个。

默认值: 'iso-8601'

TIME_INPUT_FORMATSopen in new window

默认使用的格式字符串列表,用于解析 TimeField 序列化字段的输入。

可以是包含字符串 'iso-8601' 或 Python strftime 格式字符串的列表。

默认值:['iso-8601']


编码open in new window

UNICODE_JSONopen in new window

设置为 True 时,JSON 响应将允许 unicode 字符作为响应。例如:

{"unicode black star":"★"}

当设置为 False 时,JSON 响应将转义非ascii字符,如下所示:

{"unicode black star":"\u2605"}

两种样式都符合 RFC 4627,并且在语法上都是有效 JSON。在检查 API 响应时,unicode 样式更受用户欢迎。

默认值: True

COMPACT_JSONopen in new window

当设置为 True 时,JSON 响应将返回紧凑表示,':'',' 字符之后没有间隔。例如:

{"is_admin":false,"email":"jane@example"} 

当设置为 False 时,JSON 响应将返回稍微更冗长的表示,如下所示:

{"is_admin": false, "email": "jane@example"}

默认样式是返回缩小的响应,符合 Heroku 的 API 设计准则。

默认值: True

STRICT_JSONopen in new window

当设置为 True 时,JSON 渲染和解析只会遵循语法上有效的 JSON,而 Python 的 json 模块接受的扩展浮点值(naninf-inf)会引发异常。这是推荐的设置,因为通常不支持这些值。例如,Javascript 的 JSON.Parse 和 PostgreSQL 的 JSON 数据类型都不接受这些值。

当设置为 False 时,JSON 的渲染和解析将是宽松的。但是,这些值仍然无效,需要在代码中专门处理。

默认值:True

COERCE_DECIMAL_TO_STRINGopen in new window

在不支持原生十进制类型的 API 表示形式中返回小数对象时,通常最好将该值作为字符串返回。这样可以避免二进制浮点实现所带来的精度损失。

设置为 True 时,序列化 DecimalField 类将返回字符串而不是 Decimal 对象。设置为 False 时,序列化将返回 Decimal 对象,默认 JSON 编码器将作为浮点数返回。

默认值: True


View names and descriptionsopen in new window

以下设置用于生成视图名称和描述,如 OPTIONS 请求的响应中所使用的,以及可浏览 API 中使用的设置。

VIEW_NAME_FUNCTIONopen in new window

表示生成视图名称时应使用的函数的字符串。

这应该是一个具有以下签名的函数:

view_name(cls, suffix=None)
  • cls: 视图类。通常,名称函数会在生成描述性名称时通过访问 cls .__ name__ 来检查类的名称。
  • suffix: 区分视图中各个视图时使用的可选后缀。

默认值:'rest_framework.views.get_view_name'

VIEW_DESCRIPTION_FUNCTIONopen in new window

表示生成视图描述时应使用的函数的字符串。

此设置可以更改为支持除默认 markdown 以外的标记样式。例如,你可以使用它支持在可浏览的 API 中输出的视图文档字符串中的 rst 标记。

这应该是一个具有以下签名的函数:

view_description(cls, html=False)
  • cls: 视图类。通常,description 函数会在生成描述时检查类的文档字符串,方法是访问 cls .__ doc__
  • html: 指示是否需要 HTML 输出的布尔值。在可浏览的 API 中使用时为 true,在生成 OPTIONS 响应时使用 False

默认值: 'rest_framework.views.get_view_description'

HTML Select 字段截取open in new window

用于在可浏览 API 中渲染关系字段的 select 字段截取的全局设置。

HTML_SELECT_CUTOFFopen in new window

html_cutoff 值的全局设置。必须是整数。

默认值: 1000

HTML_SELECT_CUTOFF_TEXTopen in new window

代表 html_cutoff_text 全局设置的字符串。

默认值: "More than {count} items..."


杂项设置open in new window

EXCEPTION_HANDLERopen in new window

一个字符串,表示在返回任何给定异常的响应时应使用的函数。如果该函数返回 None,则会引发 500 错误。

此设置可以更改为支持默认 {"detail": "Failure..."} 响应以外的错误响应。例如,你可以使用它来提供 API 响应,如 {"errors": [{"message": "Failure...", "code": ""} ...]}.

这应该是一个具有以下签名的函数:

exception_handler(exc, context)
  • exc: 异常。

默认值: 'rest_framework.views.exception_handler'

NON_FIELD_ERRORS_KEYopen in new window

表示应该用于序列化错误的关键字的字符串,该字符串不引用特定字段,而代表一般错误。

默认值:'non_field_errors'

URL_FIELD_NAMEopen in new window

一个字符串,表示用于由 HyperlinkedModelSerializer 生成的 URL 字段的键

默认值: 'url'

NUM_PROXIESopen in new window

一个 0 或更大的整数,可用于指定 API 在后台运行的应用程序代理的数量。这允许限流器更准确地识别客户端 IP 地址。如果设置为 None,那么限流器将使用宽松的 IP 匹配方式。

默认值:None