利用rest framework搭建Django API过程解析

时间:2021-05-22

思路步骤:

创建一个可以序列化的类

去数据库取数据交给序列化的类处理

把序列化的数据返回前端

操作流程:

# 安装模块

pip install djangorestframework

# settings.py配置

1. apps中注册

INSTALLED_APPS = [ '...', 'rest_framework',]

2.末尾添加以下代码,访问权限

REST_FRAMEWORK = { # Use Django's standard `django.contrib.auth` permissions, # or allow read-only access for unauthenticated users. 'DEFAULT_PERMISSION_CLASSES': [ 'rest_framework.permissions.DjangoModelPermissionsOrAnonReadOnly' ]}

# app目录下创建rest_serializer.py文件,用来写处理序列化的类

# models.py中有个User类,类下有'username', 'password'字段from crm import modelsfrom rest_framework import serializers class UserSerializer(serializers.HyperlinkedModelSerializer): # 序列化哪个类以及其类下的字段 class Meta: model = models.User # 序列化models中User类 fields = ( 'username', 'password',) # 序列化字段,此处无外键,有外键的话需要另写对应的序列化类

# app目录下创建rest_views.py文件,从数据库获取数据并交给序列化类处理

from rest_framework import viewsetsfrom crm.rest_serializer import UserSerializerfrom crm import modelsclass UserViewSet(viewsets.ModelViewSet): queryset = models.User.objects.all() # 取User表所有数据,变量名queryset固定 serializer_class = UserSerializer # 给UserSerializer类序列化,变量名serializer_class固定

# app目录urls.py文件,引入url,此处为二级分发,记得总url需要分发,url(r'^crm/', include('crm.urls')),

from django.conf.urls import url,includefrom rest_framework import routersfrom crm.rest_views import UserViewSetrouter = routers.DefaultRouter() # 实例router.register(r'users', UserViewSet) # 注册urlpatterns = [ url(r'^api/', include(router.urls)),]

运行即可!

更多资料请戳:https://www.django-rest-framework.org/

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章