对Django的restful用法详解(自带的增删改查)


Posted in Python onAugust 28, 2019

什么是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过滤

?page=2&per_page=100:指定第几页,以及每页的记录数。

?sortby=name&order=asc:指定返回结果按照哪个属性排序,以及排序顺序。

?animal_type_id=1:指定筛选条件

状态码

服务端向用户返回请求api的结果,在结果中包含了status codes 状态码的,可以通过状态码去判断请求api的状态是成功还是失败

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然后写入restful
from 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

对Django的restful用法详解(自带的增删改查)

创建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

对Django的restful用法详解(自带的增删改查)

对应的方法

在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用法详解(自带的增删改查)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
使用wxpython实现的一个简单图片浏览器实例
Jul 10 Python
浅谈Python中用datetime包进行对时间的一些操作
Jun 23 Python
Windows和Linux下Python输出彩色文字的方法教程
May 02 Python
Python实现的本地文件搜索功能示例【测试可用】
May 30 Python
Python+selenium 获取一组元素属性值的实例
Jun 22 Python
对python读取zip压缩文件里面的csv数据实例详解
Feb 08 Python
OpenCV-Python 摄像头实时检测人脸代码实例
Apr 30 Python
pytorch下使用LSTM神经网络写诗实例
Jan 14 Python
Django Admin后台添加数据库视图过程解析
Apr 01 Python
Python字节单位转换(将字节转换为K M G T)
Mar 02 Python
使用numpy nonzero 找出非0元素
May 14 Python
python区块链持久化和命令行接口实现简版
May 25 Python
Python closure闭包解释及其注意点详解
Aug 28 #Python
python opencv调用笔记本摄像头
Aug 28 #Python
Python threading的使用方法解析
Aug 28 #Python
Numpy对数组的操作:创建、变形(升降维等)、计算、取值、复制、分割、合并
Aug 28 #Python
Python logging设置和logger解析
Aug 28 #Python
Python shelve模块实现解析
Aug 28 #Python
解决python明明pip安装成功却找不到包的问题
Aug 28 #Python
You might like
php 数组的创建、调用和更新实现代码
2009/03/09 PHP
PHP Pear 安装及使用
2009/03/19 PHP
php操作mysql数据库的基本类代码
2014/02/25 PHP
纯PHP生成的一个树叶图片画图例子
2014/04/16 PHP
PHP模版引擎原理、定义与用法实例
2019/03/29 PHP
在 Laravel 6 中缓存数据库查询结果的方法
2019/12/11 PHP
JavaScript 异步调用框架 (Part 5 - 链式实现)
2009/08/04 Javascript
通过Jscript中@cc_on 语句识别IE浏览器及版本的代码
2011/05/07 Javascript
javascript中的缓动效果实现程序
2012/12/29 Javascript
jQuery 文本框得失焦点的简单实例
2014/02/19 Javascript
JS实现窗口加载时模拟鼠标移动的方法
2015/06/03 Javascript
jq实现左侧显示图片右侧文字滑动切换效果
2015/08/04 Javascript
jQuery地图map悬停显示省市代码分享
2015/08/20 Javascript
JSON字符串和JSON对象相互转化实例详解
2017/01/05 Javascript
教你用十行node.js代码读取docx的文本
2017/03/08 Javascript
css和js实现弹出登录居中界面完整代码
2017/11/26 Javascript
细说webpack源码之compile流程-rules参数处理技巧(1)
2017/12/26 Javascript
ES6数组与对象的解构赋值详解
2019/06/14 Javascript
使用js在layui中实现上传图片压缩
2019/06/18 Javascript
javascript实现图片轮播代码
2019/07/09 Javascript
vue实现下拉加载其实没那么复杂
2019/08/13 Javascript
wxPython定时器wx.Timer简单应用实例
2015/06/03 Python
Python简单实现子网掩码转换的方法
2016/04/13 Python
Python实现的根据IP地址计算子网掩码位数功能示例
2018/05/23 Python
Python中flatten( )函数及函数用法详解
2018/11/02 Python
Python 普通最小二乘法(OLS)进行多项式拟合的方法
2018/12/29 Python
最新PyCharm 2020.2.3永久激活码(亲测有效)
2020/11/26 Python
使用分层画布来优化HTML5渲染的教程
2015/05/08 HTML / CSS
挪威户外活动服装和装备购物网站:Bergfreunde挪威
2016/10/20 全球购物
中专毕业生的自我鉴定
2013/12/01 职场文书
幼儿园保育员辞职信
2014/01/12 职场文书
高中军训感言200字
2014/02/23 职场文书
2014年教师批评与自我批评思想汇报
2014/09/20 职场文书
python 如何获取页面所有a标签下href的值
2021/05/06 Python
MySQL 表空间碎片的概念及相关问题解决
2021/05/07 MySQL
php中配置文件保存修改操作 如config.php文件的读取修改等操作
2021/05/12 PHP