django的restfulapi
Django Rest framework 的流程大概是这样的
- 建立 Models
- 依靠 Serialiers 将数据库取出的数据 Parse 为 API 的数据(可用于返回给客户端,也可用于浏览器显示)
- ViewSet 是一个 views 的集合,根据客户端的请求(GET、POST等),返回 Serialiers 处理的数据
- 权限 Premissions 也在这一步做处理
- ViewSet 可在 Routers 进行注册,注册后会显示在 Api Root 页上
- 在 urls 里注册 ViewSet 生成的 view,指定监听的 url
Serializers,这个相当于 Django 的 Form
其实 viewset 反而是最简单的部分,rest_framework 原生提供了四种 ViewSet
ViewSet
GenericViewSet
- 继承于
GenericAPIView
- 继承于
ModelViewSet
- 自身提供了六种方法
list
create
retrieve
update
partial_update
destroy
ReadOnlyModelViewSet
class DataBaseInfoViewSet(viewsets.ModelViewSet):
permission_classes = (permissions.IsAuthenticated,)
queryset = DataBaseInfo.objects.all()
serializer_class = DataBaseInfoSerializer
filter_backends = (filters.DjangoFilterBackend,)
filter_fields = [
'id',
'db_name', ] def get_queryset(self):
queryset = self.queryset
queryset = queryset.prefetch_related('create_user')
return queryset
Filters
前面根据 serializers 和 viewset 我们已经可以很好的提供数据接口和展示了。但是有时候我们需要通过 url参数 来对数据进行一些排序或过滤的操作,为此,rest-framwork 提供了 filters 来满足这一需求。
全局filter
可以在 settings 里指定应用到全局的 filter:
REST_FRAMEWORK = {
'DEFAULT_FILTER_BACKENDS': ('rest_framework.filters.DjangoFilterBackend',)}
viewset 的 filter
也可以为 viewset 分别指定 filter,方法就是在定义 viewset 的时候定义一个名为 filter_backend
的类变量:
class UserListView(generics.ListAPIView):
queryset = User.objects.all()
serializer = UserSerializer
filter_backends = (filters.DjangoFilterBackend,)
Premissions
顾名思义就是权限管理,用来给 ViewSet 设置权限,使用 premissions 可以方便的设置不同级别的权限:
- 全局权限控制
- ViewSet 的权限控制
- Method 的权限
- Object 的权限
被 premission 拦截的请求会有如下的返回结果:
- 当用户已登录,但是被 premissions 限制,会返回
HTTP 403 Forbidden
- 当用户未登录,被 premissions 限制会返回
HTTP 401 Unauthorized
默认的权限
rest_framework 中提供了七种权限
AllowAny
# 无限制IsAuthenticated
# 登陆用户IsAdminUser
# Admin 用户IsAuthenticatedOrReadOnly
# 非登录用户只读DjangoModelPermissions
# 以下都是根据 Django 的 ModelPremissionsDjangoModelPermissionsOrAnonReadOnly
DjangoObjectPermissions
全局权限控制
在 settings.py 中可以设置全局默认权限
# settings.py
REST_FRAMEWORK = {
'DEFAULT_PERMISSION_CLASSES': (
'rest_framework.permissions.AllowAny',
),}
ViewSet 的权限
可以设置 permission_classes
的类属性来给 viewset 设定权限,restframework 会检查元组内的每一个 premission,必须要全部通过才行。
class UserViewSet(viewsets.ReadOnlyModelViewSet):
queryset = User.objects.all()
serializer_class = UserSerializer
# 设置权限,是一个元组
permission_classes = (permissions.IsAuthenticated,)
创建序列器
序列器的作用
在开始 我们的 Web API 之前,我们需要考虑 如何完成 snippet 实例 的序列化和反序列化。在restframework 里面 这个动作被分成了2部分
1.序列器: 用于完成 实例 和 python数据结构的 转换
2.使用python的json模块来完成 python数据结构 和 json 数据结构的 转换 (Django对其进行了封装,restframework已对其进行了封装,这个后面会说)
因此这个 序列器的作用就是用来完成 实例和python数据结构的 一个转换, 因此这个概念和 Django 的from很像。他的定义方式也和Django Form很像,
定义序列器
定义一个序列器 主要需要定义2部分:
1. 定义序列化/反序列化的字段
2.重写Serializer类的 create方法,和update方法,这2个方法必须重写,因为 Serializer类的save方法会 调用 create方法和 update 方法来创建和更新数据, 这样将 create方法 和 update 方法独立出来, 让用户自己实现, 使得 serialzer 在序列化时 具有 高度的灵活性。
在 snippets app 下 创建一个 serializers.py文件
使用序列器
序列器仅能帮我们把 python数据结构(OrderedDict)和 snippets对象 进行转换, 如果想 转化成json数据格式,可以使用json模块,这里使用restframework为我们封装好的 JSONRender 和 JSONParser 对象 来完成 Json数据 和 python 数据的转换。
序列化
1.完成snippet对象和python内部数据结构(OrderedDict)的转换
2.完成python数据结构(OrderedDict) 到 Json数据结构的转换
反序列化
1.完成Json数据结构 到Python内部数据结构(OrderedDict)的转换
2.获得的python内部结构的数据 转换成 snippet对象(由于我们定义了 create 和 update方法,所有转换成snippet对象后 ,会隐式的存入数据库)
如何序列化queryset对象
默认情况下 序列器 仅能序列化一个对象,而 queryset 是 多个表实例对象的 列表。 因此如果想要一次序列化多个对象, 也就是序列化queryset对象
Serializer 类提供了一个 布尔选项,只要开启这个布尔选项(many=True),那么就可以序列化 queryset对象了
使用Model Serialser 优化 序列器
问题与优化
我们发现 序列器里面定义的字段, 基本都和 数据模型里面的 字段重复了, 为了保证代码的简洁,需要去重。
Django Form 提供 Form 和 ModleForm, 而restframework 也同时提供 Serializer 和 ModelSerializer
这里的ModleSerializer 就是使 序列器 的定义更简洁, 更优雅的一个类
注意,ModelSerializer 对于 Serializer 并没有做说明特别的 处理, 他的作用仅仅是我们建立序列器的一种 快捷方法,这里ModelSerializer帮我们做了2件事儿
1.根据Modle的字段 自动化设置序列器的字段类型
2.实现了默认的 create 方法, 和 update方法 (当然如果和我们的需求不想符, 你可以重写这些方法)
优化后的代码
修改snippets/serializers.py, 实现我们优化过后的 序列器定义方法
1
2
3
4
|
class SnippetSerializer(serializers.ModelSerializer): class Meta: model = Snippet fields = ( 'id' , 'title' , 'code' , 'linenos' , 'language' , 'style' )
|
Restframework 提供一种机制 来让 开发人员仅仅 专注于 模型和API交互 的开发, 这种机制就是 章要讲的 ViewSet 和 Router。
Viewset(集合视图)- 他将一组 相同资源的不同视图 ,集合成了一张视图, 而开人人员需要编写的是 对这个资源的处理方法(比如 read, update), 而不是实现http的处理方法(get, update)。因此 Viewset是一个抽象层, 他完成了 http方法 <—> 资源处理方法
Router(路由器)- 更具一种 共同的约定 自动处理url, 主要是url pattern的命名。
使用Router
Router功能简介
1. 分解viewset
Router会为我们完成view的分解, 但是分解是遵循一定规则的,Default Router 内置了一个默认映射表:
get — list
post — create
get — retrieve
put — update
patch — partial-update
delete — destroy
以上这些默认的方法,就是Default Router 的 标准方法
如果我们有自定义的 方法需要映射 就需要使用 2个装饰器 来完成映射: HTTP 方法 — 资源方法
@list_route
这个装饰器 会获取资源对象的列表, 常用于 需要操作多个对象的时候。
@detail_route
这个装饰器 包含一个 pk, 会获取对于 pk 的单个 资源对象。常用于 操作单个对象的时候。
method参数: 这两个装饰器 都可以传人一个 method 参数, 用于 指定这个 资源方法 映射的对应的 http方法。
其他关键字也可以传入
django的restfulapi的更多相关文章
- Django的RestfulAPI框架RestFramework
Django的Restful-API框架 安装框架 #sudo pip3 install django #sudo pip3 install markdown #sudo pip3 install d ...
- Django从Models 10分钟建立一套RestfulApi
目录 Django从Models 10分钟建立一套RestfulApi Django从Models 10分钟定制一个Admin后台 简介 Django是一套完善而强大的web开发框架, 结合Djang ...
- 【Django】 rest-framework和RestfulAPI的设计
[rest-framework] 这是一个基于django才能发挥作用的组件,专门用于构造API的. 说到API,之前在其他项目中我也做过一些小API,不过那些都是玩票性质,结构十分简单而且要求的设计 ...
- Django JWT Token RestfulAPI用户认证
一般情况下我们Django默认的用户系统是满足不了我们的需求的,那么我们会对他做一定的扩展 创建用户项目 python manage.py startapp users 添加项目apps INSTAL ...
- [django]restfulapi请求规范
http://www.ruanyifeng.com/blog/2014/05/restful_api.html 方法及作用: GET(SELECT) :从服务器取出资源(一项或多项). POST(CR ...
- Django Rest Framework-介绍
什么是RESTful REST与技术无关,代表的是一种软件架构风格,REST是Representational State Transfer的简称,中文翻译为"表征状态转移" RE ...
- Django之REST framework源码分析
前言: Django REST framework,是1个基于Django搭建 REST风格API的框架: 1.什么是API呢? API就是访问即可获取数据的url地址,下面是一个最简单的 Djang ...
- 01: RestfulAPI与HTTP
1.1 RestfulAPI与HTTP简介 1.什么是RestfulAPI 1.REST直接翻译:表现层状态转移,实质就是一种面向资源编程的方法 2.REST描述的是在网络中client和server ...
- [py]django的manytomany字段和后台搜索过滤功能
我本来想搞下Django之select_related和prefetch_related的区别,看到这里有djangoapi的知识, 之前搞过django restfulapi,http://blog ...
随机推荐
- 【Java 线程的深入研究1】Java 提供了三种创建线程的方法
Java 提供了三种创建线程的方法: 通过实现 Runnable 接口: 通过继承 Thread 类本身: 通过 Callable 和 Future 创建线程. 1.通过实现 Runnable 接口来 ...
- JavaSE(八)之Map总结
上一篇是总结了Collection接口的各种实现类,这一篇我将分享的是Map的总结,希望大家点评! 一.Map接口 1.1.为什么Collection不能满足集合的所有功能? Collection接口 ...
- (记录)eclipse常用设置步骤
代码风格文件导入: https://blog.csdn.net/wangming520liwei/article/details/53911736 注释中的author修改: https://jing ...
- 【转载】Redhat5和6 YUM源配置的区别
Redhat5和6 YUM源配置的区别 一.概述 随着各个软件版本的不断升级,我们需要掌握的软件特性也越来越多,技术的不断更新也促进了我们脑细胞的循环. 今天在配置RedHat6.3的yum源 ...
- 在word文档中如何插入Mathtype公式
将mathtype公式插入到word文档中,是mathtype公式编辑器最基本的操作.当在Mathtype数学公式编辑器中编辑好公式之后,点击文件->更新XXX文档(XXX为当前编辑的word文 ...
- 验证手机号码的JS方法
function Checkreg() { //验证电话号码手机号码,包含153,159号段 if (document.form.phone.value=="" && ...
- phpcms二级栏目的调用
1.二级栏目的调用方法 {php $data = subcat($module, $catid);} {loop $data $n $r} {if $r[ismenu]} {$r[catname]} ...
- Ubuntu16.04下Mongodb(离线安装方式|非apt-get)安装部署步骤(图文详解)(博主推荐)
不多说,直接上干货! 说在前面的话 首先,查看下你的操作系统的版本. root@zhouls-virtual-machine:~# cat /etc/issue Ubuntu LTS \n \l r ...
- JBPM4.4_执行流程实例
1. 执行流程实例 1.1. 启动流程实例 说明:流程实例创建后,直接就到开始活动后的第一个活动,不会在开始活动停留. 1.1.1. 示例代码1:使用指定key的最新版本的流程定义启动流程实例 Pro ...
- eclipse、tomca和jvm的相关内存配置
1, 设置Eclipse内存使用情况 修改eclipse根目录下的eclipse.ini文件 -vmargs //虚拟机设置 -Xms40m ...