时间:2021-05-22
思路步骤:
创建一个可以序列化的类
去数据库取数据交给序列化的类处理
把序列化的数据返回前端
操作流程:
# 安装模块
# 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邮箱联系删除。
在Django中用rest_framework写API,写了一个用户注册的API,并测试成功。本人环境:Django==2.2.1;djangorestfram
我使用django-rest-framework开发了一个API.我正在使用ModelSerializer返回模型的数据.models.pyclassMetaT
前言我们在django-rest-framework解析请求参数文章中完成了接口文档到参数解析,一个完整的流程中还缺少对数据库的操作.本篇内容为django连接
如果没有设置分页,django-rest-framework会将所有资源类表序列化后返回,如果资源很多,就会对网站性能造成影响。为此,我们来给博客文章列表API
django-rest-framework类视图拓展自django的类视图,只是针对数据的序列化和反序列化等逻辑做了封装。django-rest-framewo