Django5+DRF入门开发学习教程

2024-02-0409:49:09后端程序开发Comments941 views字数 4295阅读模式

官方文档:https://www.django-rest-framework.org/文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

创建项目

# 创建目录
mkdir drf_demo
cd drf_demo

# 创建虚拟环境
python -m venv evnv
venv/Scripts/activate

# 安装Django
pip install django

# 安装DRF
pip install djangorestframework

# 创建Django项目
django-admin startproject drf_demo .

# 创建应用
python manage.py startapp quickstart

# 同步数据库
python manage.py migrate

# 创建超级管理员
python manage.py createsuperuser --username zhangdapeng --email zhangdapeng@qq.com

注册应用

使用Pycharm打开项目,修改配置文件,注册刚才创建的quickstart应用:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'quickstart',
]

创建序列化文件

首先,我们要定义一些序列化器。让我们创建一个名为 tutorial/quickstart/serializers.py 的新模块,用于数据表示。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

from django.contrib.auth.models import Group, User
from rest_framework import serializers


class UserSerializer(serializers.HyperlinkedModelSerializer):
    class Meta:
        model = User
        fields = ['url', 'username', 'email', 'groups']


class GroupSerializer(serializers.HyperlinkedModelSerializer):
    class Meta:
        model = Group
        fields = ['url', 'name']

请注意,在本例中我们使用的是 HyperlinkedModelSerializer 的超链接关系。您也可以使用主键和其他各种关系,但超链接是良好的 RESTful 设计。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

创建视图

好了,我们还是写一些视图吧。打开 tutorial/quickstart/views.py 开始输入。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

from django.contrib.auth.models import Group, User
from rest_framework import permissions, viewsets

from .serializers import GroupSerializer, UserSerializer


class UserViewSet(viewsets.ModelViewSet):
    """
    允许查看或编辑用户的 API 端点。
    """
    queryset = User.objects.all().order_by('-date_joined')
    serializer_class = UserSerializer
    permission_classes = [permissions.IsAuthenticated]


class GroupViewSet(viewsets.ModelViewSet):
    """
    允许查看或编辑组的 API 端点。
    """
    queryset = Group.objects.all()
    serializer_class = GroupSerializer
    permission_classes = [permissions.IsAuthenticated]

与其编写多个视图,我们不如将所有常见的行为归类到名为 ViewSets 的类中。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

如果需要,我们可以很容易地将这些视图分解成单个视图,但使用视图集可以使视图逻辑井井有条,而且非常简洁。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

配置路由

好了,现在我们来连接 API URL。进入 tutorial/urls.py...文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

from django.urls import include, path
from rest_framework import routers

from quickstart import views

# 创建子路由
router = routers.DefaultRouter()
router.register(r'users', views.UserViewSet)
router.register(r'groups', views.GroupViewSet)

# 使用自动 URL 路由为我们的应用程序接口布线。
# 此外,我们还提供了可浏览 API 的登录 URL。
urlpatterns = [
    path('', include(router.urls)),
    path('api-auth/', include('rest_framework.urls', namespace='rest_framework'))
]

urlpatterns += router.urls

由于我们使用的是视图集而不是视图,因此只需用路由器类注册视图集,就能自动生成 API 的 URL conf。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

同样,如果我们需要对应用程序接口的 URL 进行更多控制,我们也可以简化为使用基于类的常规视图,并明确编写 URL conf。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

最后,我们在可浏览 API 中加入了默认登录和注销视图。这是可选项,但如果您的应用程序接口需要身份验证,而您又想使用可浏览的应用程序接口,这一点就非常有用了。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

配置分页

分页可以控制每页返回多少个对象。要启用分页功能,请在 tutorial/settings.py 中添加以下几行文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

# DRF 接口配置
REST_FRAMEWORK = {
    'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
    'PAGE_SIZE': 10
}

配置应用

在 INSTALLED_APPS 中添加 "rest_framework"。设置模块将位于 tutorial/settings.py 中文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'quickstart',
    'rest_framework',
]

测试我们的API

现在我们可以测试我们构建的 API 了。让我们从命令行启动服务器。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

python manage.py runserver

现在,我们可以使用 curl 等工具从命令行访问我们的 API...文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

bash: curl -u admin -H 'Accept: application/json; indent=4' http://127.0.0.1:8000/users/
Enter host password for user 'admin':
{
    "count": 1,
    "next": null,
    "previous": null,
    "results": [
        {
            "url": "http://127.0.0.1:8000/users/1/",
            "username": "admin",
            "email": "admin@example.com",
            "groups": []
        }
    ]
}

或者使用 httpie 命令行工具。如果没有,则执行pip install httpie先安装。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

(venv) PS D:\tmp\drf_demo> http -a zhangdapeng http://127.0.0.1:8000/users/
http: password for zhangdapeng@127.0.0.1:8000::
HTTP/1.1 200 OK
Allow: GET, POST, HEAD, OPTIONS
Content-Length: 158
Content-Type: application/json
Cross-Origin-Opener-Policy: same-origin
Date: Sun, 07 Jan 2024 03:24:30 GMT
Referrer-Policy: same-origin
Server: WSGIServer/0.2 CPython/3.12.0
Vary: Accept, Cookie
X-Content-Type-Options: nosniff
X-Frame-Options: DENY

{
    "count": 1,
    "next": null,
    "previous": null,
    "results": [
        {
            "email": "zhangdapeng@qq.com",
            "groups": [],
            "url": "http://127.0.0.1:8000/users/1/",
            "username": "zhangdapeng"
        }
    ]
}

或直接通过浏览器访问 URL http://127.0.0.1:8000/users/...文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/59107.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/bc/59107.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定