DRF cbv源码分析 restful规范10条 drf:APIView的源码 Request的源码 postman的安装和使用
| CBV 执行流程 |
路由配置:url(r'^test/',views.Test.as_view()), --> 根据路由匹配,一旦成功,会执行后面函数(request) --> 本质就是执行了as_view内部的view函数 --> 内部又调用了self.dispatch --> 根据请方式,执行不同的方法(必然get请求,就会执行视图类的get方法)
自己分装一个类 重写dispatch方法,在执行父类的dispatch之前,写一些逻辑,请求来了,就会执行这些逻辑
from django.views import View
class APIView(View):
def dispatch(self, request, *args, **kwargs):
# 写控制条件
ret = super().dispatch(request,*args,**kwargs)
return ret class Test(APIView):
def get(self,request,*args,**kwargs):
return HttpResponse('ok收到了了')
| restful规范 |
面向资源架构 10条
1 API与用户的通信协议,总是使用HTTPs协议 这个协议比HTTP协议更安全一些
2 域名有区分 ① https://api.example.com @https://example.com/api/ 两种书写方式
3 版本 可以放在路径中 可以放在请求头中
https://api.example.com/v1/
4 路径,是网络上任何东西都是资源,均使用名词表示(重点)
https://api.example.com/imgs
5 通过method 区分是什么操作(重点)
get 表示获取
post 提交数据表示新增
delete表示删除
patch/put 表示修改
6 过滤,通过在url上传参的形式传递搜索条件 是查询所有 还是某一个分类或标签下的某一个资源
7 状态码
{'code' :100}
8 信息处理,错误处理应返回错误信息
{'code':101,'msg':'用户名或密码错误'}
{'code':100,'msg':'登录成功'}
9 返回结果,针对不同操作,服务器像用户返回的结果
get请求的获取所有资源 127.0.0.1/api/v1/books 获取所有图书 {'code':100,'msg':'success',data:[{},{},{}]}
get获取一个资源 127.0.0.1/api/v1/books/3 获取id为3的图书 {'code':100,'msg':'success',data:{'name':'小右'}}
新增数据,把新增的数据再返回
修改了数据,返回完整的资源对象
删除数据,返回一个空文档
10 返回结果中提供链接
| 基于原生django开发restful的接口 |
写获取图书接口 前端不用用queryset 用json转成字符串
JsonResponse 默认是传送字典类型 想要传送非字典类型需要设置safe=False 中文会被JsonResponse按照ascii编码
def lide(request):
if request.method == 'GET':
books = models.Book.objects.all()
# 列表推导式
l = [{'name': book.name, 'publish': book.publish} for book in books]
res = {'code': 100, 'msg': '查询成功', 'data': l} # 把它发回前端
return JsonResponse(res, safe=False, json_dumps_params={'ensure_ascii': False})
源码

| drf:APIView的源码,Request的源码 |
安装: pip3 install djangorestframework 第二种是pycharm安装
使用: 第一步,在写视图,都写cbv
from rest_framework.views import APIView
class Books(APIView):
def get(self,request):
'''
request是被封装后的request,原生的request在requeset._rquest
如果想要用用原生的request中的属性,还是原来的用法,因为Request重写了__getattr__方法
原生django只能处理urlencoded和formdata编码,如果是jason格式,原生django是不能处理的,需要自己从body中自行处理的 也就是前面说的
只有json才可以看body request.data 不管前端传输的编码格式是urlencoded,formdata或者json,都是从里面取值 request.data
request.query_params 是原来django原生的GET中的数据
self.FILES 就是上传的文件
:param request:
:return:
''' dic={'name':'lqz','age':30,'height':178,'wife':['liuyifei','dilireba','langlixiaobailong']} return JsonResponse(dic)
在settings文件中配置 INSTALLED_APPS=[...,'rest_framework']
源码分析:
继承了APIView之后
1所有的请求都没有csrf的认证了
忽略校验
2 在APIView中as_view本质上还是调用了父类的as_view(View的as_view)
3 as_view中调用dispath --> 这个dispatch是APIView的dispatch(先从自身查找没有找父类APIView的找到dispatch)
APIView的dispatch方法:

1 对原生request对象做了一层装(面向对象的封装),以后再用的request对象是新的request对象



原生request对象里面有个GET(以get形式提交的数据)都拆到environ内部 django把数据取出来转成了QueryDict的对象
看具体怎么封装的打印一下request._request的类型拿到类之后from impot点击进入

QueryDict对象 GET方法上面的装饰器可能是个缓存的装饰器 不然每次都实例化一个QueryDict对象浪费资源

session不是原生requeset对象的属性,在中间件中放进去的(django.contrib.sessions.middleware.SessionMiddleware)
2 在APIView中self.initial(request,*args,**kwargs),里面有频率控制,权限控制和认证相关
3 根据请求方法执行视图类中的相应方法
视图类中方法的request对象,已经变成了封装后的request
drf的Request类:
1 原生的request是self._request
2 data(post提交的数据,urlencoded,formdata编码方式的数据,json格式)
提交的data的类型并不是固定的,可能是QuerDict post提交的数据类型,也可能是字典
3 query_params 就是原生request的GET的数据
4 上传的文件是从FILES中取

5 (重点)其他的属性,直接request.属性名当属性不存在就会执行该该方法(因为Request重写了__getattr__方法)
| postman的安装和使用 |
模拟向接口发送请求,测试接口 它不是浏览器不会有重定向加反斜杠再走一遍
DRF cbv源码分析 restful规范10条 drf:APIView的源码 Request的源码 postman的安装和使用的更多相关文章
- cvb源码分析,resful规范,drf,drf序列化组件,95
1 CBV的源码分析 -Class Base View(基于类的视图) -Function Base View(基于函数的视图) -def as_view 类方法 -def view:类方法内部,闭包 ...
- Tomcat源码分析三:Tomcat启动加载过程(一)的源码解析
Tomcat启动加载过程(一)的源码解析 今天,我将分享用源码的方式讲解Tomcat启动的加载过程,关于Tomcat的架构请参阅<Tomcat源码分析二:先看看Tomcat的整体架构>一文 ...
- restful规范与rest_framework
django两种开发模式: 一.前后端不分离项目 二.前后端分离项目 什么是restful规范? 在前后端不分离的项目中,网页所需要的数据可以直接通过模板渲染的方式传递到前端页面,并且可以很好的支持d ...
- DRF框架(一)——restful接口规范、基于规范下使用原生django接口查询和增加、原生Django CBV请求生命周期源码分析、drf请求生命周期源码分析、请求模块request、渲染模块render
DRF框架 全称:django-rest framework 知识点 1.接口:什么是接口.restful接口规范 2.CBV生命周期源码 - 基于restful规范下的CBV接口 3.请求组件 ...
- drf框架,restful接口规范,源码分析
复习 """ 1.vue如果控制html 在html中设置挂载点.导入vue.js环境.创建Vue对象与挂载点绑定 2.vue是渐进式js框架 3.vue指令 {{ }} ...
- drf 简介以及部分源码分析
目录 复习 drf框架 全称:django-rest framework 知识点 接口 restful接口规范 基于restful规范的原生Django接口 主路由:url.py api组件的子路由: ...
- 接口、RESTful规范、DRF
接口 #接口:url连接,通过向链接发送不同的类型请求与参数得到相应的响应数据 #1.在视图书写处理请求的 视图函数 #2.在路由层为视图函数配置 url链接=>产生接口 #3.前台通过ajax ...
- TOMCAT8源码分析——处理请求分析(下)
前言 本文继续讲解TOMCAT的请求原理分析,建议朋友们阅读本文时首先阅读过<TOMCAT源码分析——请求原理分析(上)>和<TOMCAT源码分析——请求原理分析(中)>.在& ...
- Tomcat源码分析——请求原理分析(下)
前言 本文继续讲解TOMCAT的请求原理分析,建议朋友们阅读本文时首先阅读过<TOMCAT源码分析——请求原理分析(上)>和<TOMCAT源码分析——请求原理分析(中)>.在& ...
随机推荐
- 【转】HDU 6194 string string string (2017沈阳网赛-后缀数组)
转自:http://blog.csdn.net/aozil_yang/article/details/77929216 题意: 告诉你一个字符串和k , 求这个字符串中有多少不同的子串恰好出现了k 次 ...
- ACM之路(15)—— 字典树入门练习
刷的一套字典树的题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=120748#overview 个人喜欢指针的字典树写法,但是大力 ...
- OVS报错:s1.mgmt: version negotiation failed (we support version 0x01, peer supports version 0x04) ovs-ofctl: s1: failed to connect to socket (Broken pipe)
mininet搭建拓扑后,查看流表,发现ovs命令报错 查找原因发现系mininet创建拓扑的命令使用了OpenFlow 1.3版本 ovs dump-flows命令默认是1.0版本,因此需要在ovs ...
- yolo image.c
void draw_detections(image im, detection *dets, int num, float thresh, char **names, image **alphabe ...
- 2 ArrayList 详解
List 是有序.可重复的容器.List中每个元素都有索引标记,可以根据元素的索引标记访问元素,从而精确控制这些元素. List 接口常用的实现类:ArrayList.LinkedList.Vecto ...
- HTTP之缓存技术
1. 缓存简介 缓存是位于服务器和客户端的中间单元,主要根据用户代理发送过来的请求,向服务器请求相关内容后提供给用户,并保存内容副本,例如 HTML 页面.图片.文本文件或者流媒体文件.然后,当下一个 ...
- uni-app 的更新及碰到的问题
uni-app 的更新 我这个是针对 app 的测试,没有考虑 小程序 及 h5,如需考虑请参考 uni-app 的条件编译 当我们将文件打包好之后,我们在手机上就可以下载 apk 文件,安装到我们的 ...
- django-admin 配置
本节讲django-admin配置方法: 1.在工程配置文件中(settings.py)中启用admin组件.确保有如下两行配置: 2.执行数据库迁移的命令,确保对应的表在数据库中已经添加了 #pyt ...
- ValueAnimator
import android.animation.ValueAnimator; import android.os.Bundle; import android.support.v7.app.AppC ...
- mvc导出数据到pdf
using iTextSharp;using iTextSharp.text;using iTextSharp.text.pdf; , , ") { System.Collections.A ...