rest_framework_django学习笔记四(权限、限流)
一、权限
可以在配置文件中设置默认的权限管理类;
REST_FRAMEWORK = {
"DATETIME_FORMAT": "%Y-%m-%d %H:%M:%S", # 日期时间格式配置
"DATE_FORMAT": "%Y-%m-%d",
"DEFAULT_PERMISSION_CLASSES": [
"rest_framework.permissions.IsAuthenticated", # 只有经过身份认证确定用户身份才能访问
# 'rest_framework.permissions.IsAdminUser', # is_staff=True才能访问 —— 管理员(员工)权限
# 'rest_framework.permissions.AllowAny', # 允许所有
# 'rest_framework.permissions.IsAuthenticatedOrReadOnly', # 有身份 或者 只读访问(self.list,self.retrieve)
],
}
如果未指定,则采用如下默认配置
REST_FRAMEWORK = {
"DATETIME_FORMAT": "%Y-%m-%d %H:%M:%S", # 日期时间格式配置
"DATE_FORMAT": "%Y-%m-%d",
"DEFAULT_PERMISSION_CLASSES": [
#"rest_framework.permissions.IsAuthenticated", # 只有经过身份认证确定用户身份才能访问
# 'rest_framework.permissions.IsAdminUser', # is_staff=True才能访问 —— 管理员(员工)权限
'rest_framework.permissions.AllowAny', # 允许所有
# 'rest_framework.permissions.IsAuthenticatedOrReadOnly', # 有身份 或者 只读访问(self.list,self.retrieve)
],
}
也可以在具体的视图中通过 permission_classes 属性
from rest_framework.authentication import SessionAuthentication,BasicAuthentication
from rest_framework.permissions import IsAuthenticated
class BookModelViewSet(ModelViewSet):
authentication_classes = (SessionAuthentication,BasicAuthentication) # 认证
permission_classes = (

本文详细介绍了如何在DjangoRESTFramework中配置默认权限管理和限流策略,包括默认权限类、认证方式、自定义权限以及不同类型的限流类,如AnonRateThrottle、UserRateThrottle和ScopedRateThrottle。
最低0.47元/天 解锁文章
616

被折叠的 条评论
为什么被折叠?



