什么是rest
REST是所有Web应用都应该遵守的架构设计指导原则。
Representational State Transfer,翻译是”表现层状态转化”。
面向资源是REST最明显的特征,对于同一个资源的一组不同的操作。资源是服务器上一个可命名的抽象概念,资源是以名词为核心来组织的,首先关注的是名词。
REST要求,必须通过统一的接口来对资源执行各种操作。对于每个资源只能执行一组有限的操作。
GET用来获取资源,POST用来新建资源(也可以用于更新资源),PUT(PATCH)用来更新资源,DELETE用来删除资源。
api定义规范
http://xxx.com/api/
资源
在RESTful架构中,每个网址代表一种资源(resource),所以网址中不能有动词,只能有名词,而且所用的名词往往与数据库的表格名对应。一般来说,数据库中的表都是同种记录的”集合”(collection),所以API中的名词也应该使用复数。
举例来说,有一个API提供动物园(zoo)的信息,还包括各种动物和雇员的信息,则它的路径应该设计成下面这样。
https://api.example.com/v1/zoos https://api.example.com/v1/animals https://api.example.com/v1/employees
http请求方式
GET(SELECT):从服务器取出资源(一项或多项) POST(CREATE):在服务器新建一个资源 PUT(UPDATE):在服务器更新资源(客户端提供改变后的完整资源) PATCH(UPDATE):在服务器更新资源(客户端提供改变的属性) DELETE(DELETE):从服务器删除资源
filter过滤
"htmlcode">200 OK - [GET]:服务器成功返回用户请求的数据,该操作是幂等的(Idempotent)。 201 CREATED - [POST/PUT/PATCH]:用户新建或修改数据成功。 202 Accepted - [*]:表示一个请求已经进入后台排队(异步任务) 204 NO CONTENT - [DELETE]:用户删除数据成功。 400 INVALID REQUEST - [POST/PUT/PATCH]:用户发出的请求有错误,服务器没有进行新建或修改数据的操作,该操作是幂等的。 401 Unauthorized - [*]:表示用户没有权限(令牌、用户名、密码错误)。 403 Forbidden - [*] 表示用户得到授权(与401错误相对),但是访问是被禁止的。 404 NOT FOUND - [*]:用户发出的请求针对的是不存在的记录,服务器没有进行操作,该操作是幂等的。 406 Not Acceptable - [GET]:用户请求的格式不可得(比如用户请求JSON格式,但是只有XML格式)。 410 Gone -[GET]:用户请求的资源被永久删除,且不会再得到的。 422 Unprocesable entity - [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误。 500 INTERNAL SERVER ERROR - [*]:服务器发生错误,用户将无法判断发出的请求是否成功。具体用法
更多的需要配合postman 因此需要下载一个postman,方便更多的操作
https://www.getpostman.com/apps使用之前安装模块
pip install djangorestframework pip install django-filter在setting.py中加入参数
INSTALLED_APPS中加入'rest_framework',在app中创建一个py文件——序列化文件
比如serializers.py然后写入restfulfrom rest_framework import serializers from stu.models import Student(导入自己写的app、models) class StudentSerializer(serializers.ModelSerializer): class Meta: # 关联数据表(前面不是变量名) model = Student # 确定需要序列化的字段(返回给用户的具体表中的字段)(前面不是变量名) fields = ['id', 's_name', 's_tel'] def to_representation(self, instance): data = super().to_representation(instance) try: # 得到关联表中的字段,必须用try,否则如果存在一个没有定义i_addr的学生时,系统将报错 data['s_addr'] = instance.studentinfo.i_addr except Exception as e: data['s_addr'] = '' return data在app中views中创建类
from rest_framework import mixins,viewsets from stu.serializers import StudentSerializer from stu.models import Student class StudentEdit(mixins.ListModelMixin,# 表示可以在Postman类似的软件中只能查找所有数据 viewsets.GenericViewSet, mixins.RetrieveModelMixin, # 表示可以在Postman类似的软件中只能查找单一数据 mixins.UpdateModelMixin, # 表示可以在Postman类似的软件中更新数据 mixins.DestroyModelMixin, # 表示可以在Postman类似的软件中删除数据 mixins.CreateModelMixin): # 表示可以在Postman类似的软件中创建数据 # 查询所有信息 queryset = Student.objects.all() # 序列化 serializer_class = StudentSerializer创建urls
这里同时展示了urls不一定每次都写入进去可以用+=添加进去
注意这里写的urls不要加‘/'他会自动加载
from stu import views from rest_framework.routers import SimpleRouter router = SimpleRouter() router.register(r'student', views.StudentEdit) urlpatterns = [ # 其他url ] urlpatterns += router.urls #这里表示添加定义的url对应的方法
在postman中选入某个参数然后传入某个urls即可
增: POST http://127.0.0.1:8080/stu/addStu/1/ 删: DELETE http://127.0.0.1:8080/stu/addStu/1/ 改: UPDATE http://127.0.0.1:8080/stu/addStu/1/ 查: GET http://127.0.0.1:8080/stu/addStu/1能执行这些操作前都需要在views中定义好才行
以上这篇对Django的restful用法详解(自带的增删改查)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
Django,restful
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]