CBV 和 restful规范

知识点准备:

django的view

  • FBV:基于函数的视图
  • CBV:基于类的视图
    urls.py
    
    from django.urls import path
    from app01.views import StudentsView urlpatterns = [
    path('students/ ',StudentsView.as_view()),
    ] views.py from django.views import View
    from django.shortcuts import HttpResponse class StudentsView(View): def get(self,request,*args,**kwargs):
    return HttpResponse('GET 请求') def post(self,request,*args,**kwargs):
    return HttpResponse('POST 请求')

csrf_token

  • 原理:基于中间件的process__view()做的,用户发送get请求的时候django会给他返回一个随机字符串,下次用户发送post请求的时候,要求携带这个随机字符串,验证是否一样,
  • 免除:csrf_exempt
  • 验证:csrf_protect
  • 为什么不写在process__request()里面?

    因为它中间件要判断视图函数有没有加免除或者验证的装饰器,如果在request里面,他无法获取哪些视图函数加了装饰器。
    # 第一种:给方法加
from django.views import View
from django.views.decorators.csrf import csrf_exempt, csrf_protect
from django.utils.decorators import method_decorator class StudentsView(View): @method_decorator(csrf_exempt)
def dispatch(self, request, *args, **kwargs):
return super(StudentsView, self).dispatch(request, *args, **kwargs) def get(self, request, *args, **kwargs): print('GET')
return HttpResponse('GET请求') def post(self, request, *args, **kwargs):
return HttpResponse('POST请求') # 第二种:给类加
@method_decorator(csrf_exempt,name='dispatch')
class TeachersView(View): def get(self, request, *args, **kwargs):
print('GET')
return HttpResponse('GET请求') def post(self, request, *args, **kwargs):
return HttpResponse('POST请求')

CBV源码剖析

  • FBV 和 CBV

    基于反射实现根据请求方式不同,执行不同的方法

    原理:

    • 路由 cls.as_view()-->view()-->self.dispatch()-->反射
    • 视图:get post delete put……
    • 流程
       class StudentsView(View):
    
           def dispatch(self, request, *args, **kwargs):
    # return HttpResponse('dispath')
    func = getattr(self,request.method.lower())
    return func(request, *args, **kwargs) def get(self, request, *args, **kwargs):
    return HttpResponse('GET请求') def post(self, request, *args, **kwargs):
    return HttpResponse('POST请求') def delete(self,request,*args,**kwargs):
    return HttpResponse('DELETE请求') def put(self,request,*args,**kwargs):
    return HttpResponse('PUT请求')
    • 继承(多个类共用的功能,避免重复编写)
       class MyBaseView(object):
    def dispatch(self, request, *args, **kwargs):
    print('before')
    func = super(MyBaseView, self).dispatch(request, *args, **kwargs)
    print('after')
    return func class StudentsView(MyBaseView, View): def get(self, request, *args, **kwargs):
    print('GET')
    return HttpResponse('GET请求') def post(self, request, *args, **kwargs):
    return HttpResponse('POST请求') def delete(self, request, *args, **kwargs):
    return HttpResponse('DELETE请求') def put(self, request, *args, **kwargs):
    return HttpResponse('PUT请求')

restful规范

十条规范

  • API与用户的通信协议:https

  • 域名:

    • URL方式:www.abc.com/api/
    • 子域名方式(存在跨域问题) :www.abc.com www.api.abc.com
  • 版本:www.abc.com/api/v1/

  • 面向资源(视网络上的任何数据为资源,均使用名词、可复数):www.abc.com/api/v1/order/

  • 过滤,通过url传递搜索条件

  • 根据method不同进行不同的操作

  from django.urls import path
from app01.views import OrderView urlpatterns = [
path('order/',OrderView.as_view()),
] class OrderView(View): def get(self, request, *args, **kwargs):
return HttpResponse('获取订单') def post(self, request, *args, **kwargs):
return HttpResponse('创建订单') def delete(self, request, *args, **kwargs):
return HttpResponse('删除订单') def put(self, request, *args, **kwargs):
return HttpResponse('更新订单')
  • 状态码
  • 错误处理
  • 返回结果
  • 返回结果中就是url

django rest_framework

  • 安装:pip install djangorestframework
  • 使用
    • 认证
          from rest_framework.views import APIView
      from rest_framework.exceptions import AuthenticationFailed class MyAuthentication(object): def authenticate(self, request): token = request._request.GET.get('token')
      # 可以做用户名密码验证
      if not token:
      raise AuthenticationFailed('认证失败')
      return (1, 2) def authenticate_header(self, request):
      pass class DogView(APIView):
      authentication_classes = [MyAuthentication] def get(self, request, *args, **kwargs):
      return HttpResponse('获取小狗') def post(self, request, *args, **kwargs):
      return HttpResponse('创建小狗') def delete(self, request, *args, **kwargs):
      return HttpResponse('删除小狗') def put(self, request, *args, **kwargs):
      return HttpResponse('更新小狗')

001---CBV和restful规范的更多相关文章

  1. 一、restful规范 二、CBV(View)源代码执行流程 三、drf框架安装和简单使用

    一.restful规范 ''' 它是一个规范,面向资源架构 十条规范 1.API与用户的通讯协议,总是使用HTTPs协议,确保了网络传输的安全性 2.域名 --https://api.example. ...

  2. Django框架(十七)-- CBV源码分析、restful规范、restframework框架

    一.CBV源码分析 1.url层的使用CBV from app01 import views url(r'book/',views.Book.as_view) 2.as_view方法 as_view是 ...

  3. Django框架深入了解_01(Django请求生命周期、开发模式、cbv源码分析、restful规范、跨域、drf的安装及源码初识)

    一.Django请求生命周期: 前端发出请求到后端,通过Django处理.响应返回给前端相关结果的过程 先进入实现了wsgi协议的web服务器--->进入django中间件--->路由f分 ...

  4. DRF cbv源码分析 restful规范10条 drf:APIView的源码 Request的源码 postman的安装和使用

    CBV 执行流程 路由配置:url(r'^test/',views.Test.as_view()),  --> 根据路由匹配,一旦成功,会执行后面函数(request) --> 本质就是执 ...

  5. Django框架(十八)—— CBV源码分析、restful规范、restframework框架

    目录 CBV源码分析.restful规范.restframework框架 一.CBV源码分析 1.url层的使用CBV 2.as_view方法 3.view方法 4.dispatch方法(可以在视图层 ...

  6. Restful规范-APIView源码分析

    目录 一.Restful规范 十条规范 二.drf的简单使用 三.APIView源码分析 CBV源码分析 APIView源码分析 一.Restful规范 Restful规范是一种web API接口的设 ...

  7. DjangoRestFramework 学习之restful规范 APIview 解析器组件 Postman等

    DjangoRestFramework学习一之restful规范.APIview.解析器组件.Postman等 本节目录 一 预备知识 二 restful规范 三 DRF的APIView和解析器组件 ...

  8. restful 规范(建议)

    需求:开发cmdb,对用户进行管理. 做前后端分离,后端写api(URL),对用户表进行增删改查,应该写四个URL(还要给文档(返回值,返回,请求成功,干嘛,失败,干嘛)),然后分别写视图函数. ht ...

  9. django rest framework restful 规范

    内容回顾: . django请求生命周期 -> 执行遵循wsgi协议的模块(socket服务端) -> 中间件(路由匹配) -> 视图函数(业务处理:ORM.模板渲染) -> ...

随机推荐

  1. PHP面试常用算法(推荐)

    一.冒泡排序 基本思想: 对需要排序的数组从后往前(逆序)进行多遍的扫描,当发现相邻的两个数值的次序与排序要求的规则不一致时,就将这两个数值进行交换.这样比较小(大)的数值就将逐渐从后面向前面移动. ...

  2. lambdas vs. method groups

    Update: Due to a glitch in my code I miscalculated the difference. It has been updated. See full his ...

  3. UNIX crontab自动执行脚本

    crontab 是不会加载环境变量的你手动执行可以是因为登录了oracle用户加载了环境变量,你可以在脚本里添加,echo $ORACLE_HOME  echo $ORACLE_SID 等等试试,看看 ...

  4. 验证 Xcode是否有效方法

    苹果给出了验证 Xcode 的方法,需要用户在终端中执行下面的命令: spctl --assess --verbose /Applications/Xcode.app 如果 Xcode 从 Mac A ...

  5. 关于 Can't connect to MySQL server on 'localhost' (10061) 的一个解决方案

    问题描述: 使用Navicat for mysql 无法远程连接到本地数据库,提示Can't connect to MySQL server on 'localhost' (10038) . 本地服务 ...

  6. IOS XMPP总结

    //前言:仿weixin实现一个即时通讯的案例,支持版本7.0以上 "准备工作 创建项目时使用git" /* 显示隐藏文件,看到git的文件夹 defaults write com ...

  7. Webpack知识汇总

    介绍 webpack把任何一个文件都看成是一个模块,模块间可以相互依赖(require or import),webpack的功能就是把相互依赖的文件打包在一起.webpack本身只能处理原生的Jav ...

  8. FP又称为Monadic Programming

    什么是Monad? trait Monad[+T] { def flatMap[U]( f : (T) => Monad[U] ) : Monad[U] def unit(value : B)  ...

  9. Hive分区表创建,增加及删除

    1.创建Hive分区表,按字段分区 CREATE TABLE test1 ( id bigint , create_time timestamp , user_id string) partition ...

  10. jQuery.mobile.changePage的参数

    选项 类型:对象 属性: allowSamePageTransition(默认值:假的) 类型:布尔 默认情况下,changePage()忽略请求更改为当前活动页面.将此选项设置为true,则允许该请 ...