Django:学习笔记(3)——REST实现

时间:2023-03-08 18:16:21

Django:学习笔记(3)——REST实现

了解REST风格

  按照传统的开发方式,我们在实现CURD操作时,会写多个映射路径,比如对一本书的操作,我们会写多个URL,可能如下

web/deleteBookById
web/updateBookById
web/addBook
web/getBookById
....

  但是由于很难形成统一的URL命名规范,导致了URL命名的混乱REST是面向资源的,URL的设计只需要将资源通过合理方式暴露出来即可。比如:

web/book
web/dog
....

  资源暴露出来了,如何实现传统开发方式的CURD呢?在REST设计规范中,只需将请求方法(GET:查询、POST:新增、PUT:修改、DELETE:删除)进行相对应的设置即可

GET web/getDogs --> GET web/dogs 获取所有小狗狗
GET web/addDogs --> POST web/dogs 添加一个小狗狗
GET web/editDogs/:dog_id --> PUT web/dogs/:dog_id 修改一个小狗狗
GET web/deleteDogs/:dog_id --> DELETE web/dogs/:dog_id 删除一个小狗

Django Rest实现

安装配置django rest framework

  执行pip命令安装REST框架

pip  install djangorestframework

  安装完成后,在项目源目录的setting.py中进行配置

  Django:学习笔记(3)——REST实现

定义资源,实现序列化

  应用目录下models.py

# 定义一个用户信息
class User(models.Model):
username = models.CharField(max_length=16)
password = models.CharField(max_length=16)
gender = models.CharField(max_length=2)
mail = models.EmailField()

  应用目录下serializers.py

from .models import User
from rest_framework import serializers class UserSerializer(serializers.HyperlinkedModelSerializer):
class Meta:
model = User
fields = ('id','username','password')  

继承View,重写HTTP METHOD

  应用目录下views.py

from myweb.models import User
from .serializers import UserSerializer
from rest_framework.viewsets import ModelViewSet class UserModelSet(ModelViewSet):
queryset = User.objects.all()
serializer_class = UserSerializer  

配置URL

  项目源目录urls.py

from django.urls import path,include
from rest_framework import routers
from myweb.views import UserModelSet routers = routers.DefaultRouter()
routers.register('user',UserModelSet) urlpatterns = [
path('api/',include(routers.urls)),
]

  配置到此,一个基本的API接口已经完成。