1. 新建用户模块子项目:
2. 修改全局urls.py
from django.contrib import admin
from django.urls import path, include
from rest_framework.documentation import include_docs_urls
urlpatterns = [
path('admin/', admin.site.urls),
path('', include('apps.projects.urls')),
path('docs/', include_docs_urls(title='测试平台开发接口文档')),
path('api/', include('rest_framework.urls')),
]
3. 修改全局settings文件
REST_frameWORK = {
# 默认响应渲染类
'DEFAULT_RENDERER_CLASSES': (
# json渲染器为第一优先级
'rest_framework.renderers.JSONRenderer',
# 可浏览的API渲染器为第二优先级,不需要则取消
'rest_framework.renderers.BrowsableAPIRenderer',
),
# # django_filters.rest_framework.backends.DjangoFilterBackend
'DEFAULT_FILTER_BACKENDS': [
'django_filters.rest_framework.DjangoFilterBackend',
'rest_framework.filters.OrderingFilter'
],
# DEFAULT_PAGINATION_CLASS全局指定分页引擎类
# 'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
'DEFAULT_PAGINATION_CLASS': 'utils.pagination.ManualPageNumberPagination',
# 一定要指定, 每一页获取的条数
'PAGE_SIZE': 10,
# 指定用于支持coreapi的Schema
'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.coreapi.AutoSchema',
# 1. 指定认证类(指定的是认证的方式)
'DEFAULT_AUTHENTICATION_CLASSES': [
# 指定使用JWT Token认证
'rest_framework_jwt.authentication.JSONWebTokenAuthentication',
# DRF框架默认情况下, 使用的是用户会话认证
'rest_framework.authentication.SessionAuthentication',
'rest_framework.authentication.BasicAuthentication'
],
#
# # 2. 授权类(指定的是认证成功之后, 能干嘛!)
# # 'DEFAULT_PERMISSION_CLASSES': [
# # # DRF框架默认的权限为AllowAny(允许所有用户来访问)
# # 'rest_framework.permissions.IsAuthenticated',
# # ],
}
4. 新增用户
createsuperuser可以直接新增
5. 添加了权限需要登录后才可以请求,如果不生效可在全局里授权配置
permissions_class = [permissions.IsAuthenticated]
登录
6. 也可以使用Token认证,pip install Djangoframework-jwt
然后在全局settings里配置一下即可,如上图所示



