restful api
RESTful API 设计指南
理解RESTful架构
理解本真的REST架构风格
Python 之路,Restful API设计规范
python 之路,Django rest framework 初探
Django-rest-frameworl的使用
1.djangorestframework的安装
pip install djangorestframework pip install markdown # Markdown support for the browsable API. pip install django-filter # Filtering support
2.添加rest_framework到INSTALLED_APPS中
INSTALLED_APPS = ( ... 'rest_framework', )
3.我们将创建一个API来访问我们项目的用户信息的读写。一个REST框架所有全局设置API是保存在一个配置为rest_framework字典。通过添加到settings.py模块,来使用
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' ] }
4.简单使用
(1)序列化器定义API,与model类相关联
rest_serializer.py
from repository import models from rest_framework import serializers # Serializers define the API representation. class UserSerializer(serializers.HyperlinkedModelSerializer): class Meta: model = models.UserProfile fields = ('url', 'email', 'name', 'is_staff','is_active')
(2)视图集定义视图行为,是独立的rest_framework自定义视图,与数据表数据关联,需要register
rest_views.py
from Sale.rest_serializer import UserSerializer from repository import models from rest_framework import viewsets # # ViewSets define the view behavior. class UserViewSet(viewsets.ModelViewSet): queryset = models.UserProfile.objects.all() serializer_class = UserSerializer
#注意queryset和serializer是继承于父类的,我们不能修改
(3)在url文件中对视图集类进行注册
from django.conf.urls import url,include from rest_framework import routers from Sale.rest_views import UserViewSet router = routers.DefaultRouter() router.register(r'users', UserViewSet) urlpatterns = [ url(r'^api/', include(router.urls)), ]
5.开始访问
6.外键关联表的数据列显示
(1).需要再添加相关model的序列化类,视图集类,和url注册
rest_serializer.py添加
# Serializers define the API representation. class RoleSerializer(serializers.HyperlinkedModelSerializer): class Meta: model = models.Role fields = ('url', 'name')
rest_views.py添加
# # ViewSets define the view behavior. class RoleViewSet(viewsets.ModelViewSet): queryset = models.Role.objects.all() serializer_class = RoleSerializer
urls中注册
from Sale.rest_views import UserViewSet,RoleViewSet router.register(r'roles', RoleViewSet)
注意:此时也可以对role表添加和修改
(2)修改数据展示方法
修改序列化类即可
from repository import models from rest_framework import serializers # Serializers define the API representation. class UserSerializer(serializers.ModelSerializer): class Meta: model = models.UserProfile fields = ('url', 'email', 'name', 'is_staff','is_active','role') # Serializers define the API representation. class RoleSerializer(serializers.ModelSerializer): class Meta: model = models.Role fields = ('name',)
7.显示多层数据
修改序列化类,添加depth
from repository import models from rest_framework import serializers # Serializers define the API representation. class UserSerializer(serializers.ModelSerializer): class Meta: model = models.UserProfile depth = 3 fields = ('url', 'email', 'name', 'is_staff','is_active','role') # Serializers define the API representation. class RoleSerializer(serializers.ModelSerializer): class Meta: model = models.Role fields = ('name',)
注意:
添加depth后,会对每个设置显示的字段进行展开,而且会将其全部字段显示
8.在Django中view视图中使用,进行添加
from Sale import rest_serializer def api_test(request): serilizer_obj = None if request.method == "POST": data = json.loads(request.POST.get("data")) serilizer_obj = rest_serializer.UserSerializer(data=data) if serilizer_obj.is_valid(): serilizer_obj.save() return render(request,"sale/api-test.html",{'serilizer_obj':serilizer_obj})
可以正常进行添加操作