drf知识--01

前后端开发模式

在开发Web应用中,有两种应用模式:
        前后端混合开发: bbs 项目--render+ajax 
        1、全栈开发--前端html+后端都是一个人写
        2、前端人员:写空页面,没有模板语法,只要html,css少量js

                                把页面给后端,在里面加模板语法渲染

              后端人员:写接口
        前后端分离开发模式: 目前主流网站都是这种模式
        web,桌面应用,移动端app,ios,小程序都可以使用同一套后端

API接口

# API接口: 后端要提供api接口,在2000年Roy Fielding的博士论文中

# api 接口: 规定了前后台信息交互规则的url链接,也就是前后台信息交互的媒介
        127.0.0.1:8080/login/

# api接口有的东西
    1 url:url链接
    2 请求方式:get、post
    3 请求参数:json或xml格式的key-value类型数据  地址栏中,请求体中
    4 响应结果:json或xml格式的数据

Restful规范(重要-概念)

# 概念:REST全称是Representational State Transfer,表征性状态转移
        Web API接口的设计风格,尤其适用于前后端分离的应用模式中

# Restful规范:
1 数据的安全保障:url链接一般都采用https协议进行传输
        https是:http+ssl 安全的超文本传输协议
2 接口特征表现:在API地址中带接口标识,咱们一般放在地址栏中(放在域名中)
        https://api.baidu.com
        https://www.baidu.com/api
3 多版本共存:在url链接中带版本标识

https://api.weibo.com/2/
https://api.weibo.com/v2/
https://api.weibo.com/?version=2
https://api.weibo.com/v1/login  --->需要的参数name和pwd
https://api.weibo.com/v2/login --->需要的参数name和pwd和code 

4 数据即是资源,均使用名词(可复数):前后端交互的数据我们称之为资

# 资源名都是名词,尽量避免使用动词
https://127.0.0.1/api/v1/users
https://127.0.0.1/api/v1/get_users  # 不符合规范

5 资源操作由请求方式决定(method)    
    获取资源用get
    新增资源用post
    修改资源使用put
    删除资源使用delete

https://api.baidu.com/books      - get请求:获取所有书
https://api.baidu.com/books/1    - get请求:获取主键为1的书
https://api.baidu.com/books      - post请求:新增一本书书
https://api.baidu.com/books/1    - put请求:整体修改主键为1的书
https://api.baidu.com/books/1    - patch请求:局部修改主键为1的书
https://api.baidu.com/books/1    -delete请求:删除主键为1的书

6 url中带搜索或过滤条件
    https://api.example.com/v1/zoos?name=猴子 get请求 
7 响应状态码:响应中带状态码
    http响应状态码:1xx,2xx,3xx,4xx,5xx
    自己的状态码(用的多): 100成功,看公司自己
8 返回中带错误信息
    {code:100,msg:成功}
    "Message": "send success",
9 返回结果,符合以下规范
    GET /collection:返回资源对象的列表(数组)  [{name:xx,age:19},{name:xx,age:19},{}]
    GET /collection/resource:返回单个资源对象        {name:xx,age:19}
    POST /collection:返回新生成的资源对象             {name:yy,age:19}
    PUT /collection/resource:返回完整的资源对象       {name:xx,age:20}
    PATCH /collection/resource:返回完整的资源对象     {name:xx,age:20}
    DELETE /collection/resource:返回一个空文档        
10 返回数据中带url链接
              "url": "http://blog.sina.com.cn/zaku",

序列化和反序列化

# json pickle 序列化和反序列化

序列化

  把我们能识别的数据结构(python的字典,列表,对象)转换成其他语言(程序)能识别的数据结构      # python的字典,列表,对象-----》json格式字符串(可以是别的格式)
   前后端交互:目前通常使用 json格式字符串交互
    前后端分离模式:前端发送请求获取数据, 后端去数据库查询, QuerySet对象转成json格式字符串,再返回给前端这个过程,称之为序列化
反序列化

        把其他程序(语言)给我们的数据转换成我们能识别的数据结构
         前端给我们json格式数据  ---》转换成 字典,列表,对象
         前端给 name=lqz&age=19 格式数据 ---》转换成 字典,列表,对象
前后端分离模式
        前端携带json格式数据到后端-,后端拿到json格式数据,把数据转成对象保存到数据库这个过程,咱们称之为反序列化

Django REST framework安装和快速使用

#  有个Book单表----》对这个表进行增删查改---》原生django实现
    增加一条记录
    删除一条记录
    查询所有数据
    查询一条数据
    修改一条数据

#  使用原生django实现5个接口:

模型类:
class Book(models.Model):name = models.CharField(max_length=32)price = models.IntegerField()
路由:
path('books/', views.BookView.as_view()),
path('books/<int:pk>', views.BookDetailView.as_view()),
视图类--获取/新增:
from django.views import View
from .models import Book
from django.http import JsonResponse
import jsonclass BookView(View):def get(self, request):# 获取所有图书book_list = Book.objects.all()# 把qs [对象1,对象2]  对象转成  [{},{}]l = []for book in book_list:l.append({'name': book.name, 'price': book.price})return JsonResponse({'code': 100, 'msg': '查询成功', 'results': l})def post(self, request):data = json.loads(request.body)  # 反序列化   # request.body book = Book.objects.create(**data)return JsonResponse({'code': 100, 'msg': '新增成功', 'results': {'name': book.name, 'price': book.price}})
视图类--修改/查询/删除:
class BookDetailView(View):def get(self, request, pk):book = Book.objects.filter(pk=pk).first()return JsonResponse({'code': 100, 'msg': '查询单条成功', 'results': {'name': book.name, 'price': book.price, 'id': book.pk}})def delete(self, request, pk):Book.objects.filter(pk=pk).delete()return JsonResponse({'code':100,'msg':'删除成功'})def put(self, request, pk):print(request.POST) # 使用urlencoded编码---》put请求提交的数据,后端request.POST是取不到的# 以json形式放在请求体中---》json格式---》反序列化data=json.loads(request.body)book = Book.objects.filter(pk=pk).first()book.name=data.get('name')book.price=data.get('price')book.save()return JsonResponse({'code':100,'msg':'修改成功','result':{'name':book.name,'price':book.price}})

使用drf实现5个接口

路由:
from rest_framework.routers import SimpleRouter
router = SimpleRouter()
router.register('books', views.BookView, 'books')
urlpatterns = [
]
urlpatterns += router.urls视图类:
from .models import Book
from .serializer import BookSerializer
from rest_framework.viewsets import ModelViewSet
class BookView(ModelViewSet):queryset = Book.objects.all()serializer_class = BookSerializer
序列化类
from rest_framework import serializers
from .models import Book
class BookSerializer(serializers.ModelSerializer):class Meta:model = Bookfields = '__all__'

# json可以序列化和反序列化的类型

回顾cbv执行流程

#1 请求来了---》执行 ---》views.BookView.as_view()(request)--->执行View类中as_view类方法中得 闭包函数 view
@classonlymethod
def as_view(cls, **initkwargs):def view(request, *args, **kwargs):self = cls(**initkwargs) # BookView类实例化得到对象self.dispatch(request, *args, **kwargs) # BookView类的dispatch# 2 BookView类的dispatch没有---》View的dispatch# 根据请求方式,通过反射去视图类中【BookView】反射出跟请求方式同名的方法,执行def dispatch(self, request, *args, **kwargs):if request.method.lower() in self.http_method_names:handler = getattr(self, request.method.lower(), self.http_method_not_allowed)else:handler = self.http_method_not_allowedreturn handler(request, *args, **kwargs)# 3 以什么请求方式访问---》就会执行视图类中 跟请求方式同名的方法
比如:http://127.0.0.1:8000/books/  get请求
执行BookView类中get方法

# cbv执行流程:

1 请求来了,路由匹配成功会执行配置的视图函数内存地址 加括号,把request传入
                path('books/', views.BookView.as_view())
2 views.BookView.as_view()(request) 执行它
3 BookView中找as_view,没有,在View中找到了
4 执行View类中as_view的返回值,返回值(request),闭包函数  view
5 真正执行,执行了 view(request)
6 view 核心代码是 return self.dispatch(request)
7 本质执行的是 self.dispatch
8 在View中找到了 dispatch

         if request.method.lower() in self.http_method_names:# 通过反射去self【BookView的对象】中找到 跟请求方式同名的方法  get--》get方法handler = getattr(self, request.method.lower(), self.http_method_not_allowed)else:handler = self.http_method_not_allowedreturn handler(request, *args, **kwargs) # 真正的执行视图类中跟请求方式同名的方法

APIView执行流程源码分析(了解)

path('books/', views.BookView.as_view()),
# 1 请求来了---》会执行views.BookView.as_view()(request) ---》找as_view---》BookView找不到---》APIView中找---》as_view--->就干了一个事--》去除了csrf认证@classmethoddef as_view(cls, **initkwargs):view = super().as_view(**initkwargs) # 调用父类---》django原生View的as_viewview=csrf_exempt(view)  return view             # 当前请求,去除掉了csrf认证# 2 views.BookView.as_view()(request) 本质是执行  csrf_exempt(view)(request)-执行View的 中as_view内的view函数--》去除了csrf认证
# 3 本质在执行:self.dispatch(request, *args, **kwargs)BookView的dispatch---》BookView没有---》APIView找---》找到了def dispatch(self, request, *args, **kwargs):# 包装新的requestrequest = self.initialize_request(request, *args, **kwargs)try:# 执行三大认证self.initial(request, *args, **kwargs)# 执行跟请求方式同名的视图类中得方法if request.method.lower() in self.http_method_names:handler =getattr(self,request.method.lower(),self.http_method_not_allowed)else:handler = self.http_method_not_allowedresponse = handler(request, *args, **kwargs)            except Exception as exc:# 处理了全局异常response = self.handle_exception(exc)self.response = self.finalize_response(request, response, *args, **kwargs)return self.response

# 源码总结:1 APIView执行流程,去除csrf,执行了APIView的dispatch
                     2 执行的as_view是APIView的as_view
                     3 执行的dispatch也是APIView的dispatch

#  以后使用drf写符合restful规范的接口,都继承 APIView

# 在postman中注意:

            · /  严格
            · 删除了id为1的记录,判断查询结果有没有,再序列化

局部去除csrf认证

from django.views.decorators.csrf import csrf_exempt
@csrf_exempt  #本质 index= csrf_exempt(index)
def index(request):return render(request,'index.html')

# 继承APIView后,所有视图类,都没有csrf认证了,我们也不需要注释全局中间件了
                    csrf_exempt(view)
# 装饰器:

接口测试工具-Postman

# 概念:postman 是一个能够模拟发送http请求的 软件
#历史:是最早浏览器插件,专门做成了软件,再到收费

# postwoman:发送http请求软件

    Apifox = Postman + Swagger(接口文档) + Mock(假数据) + JMeter(压测工具)

# 使用:跨平台 mac win linux 

# 下载和安装:https://www.postman.com/
    双击:Postman-win64-Setup.exe  下载后的软件
# 安装并打开    

今日思维导图:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/221484.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【小沐学Unity3d】3ds Max 减面工具:Simplyon(Unity3d,Python)

文章目录 1、简介2、下载安装2.1 安装Simlygon插件2.2 安装USD插件 3、使用测试4、Python测试结语 1、简介 Simplygon 带有一个 Unity 插件&#xff0c;它公开了优化功能&#xff0c;例如缩减、聚合、重新划分网格、冒名顶替者&#xff08;SingleView、BillboardCloud / Veget…

软件设计模式:UML类图

文章目录 前言一、&#x1f4d6;设计模式概述1.软件设计模式的产生背景2.软件设计模式3.设计模式分类 二、&#x1f4e3;UML图1.类图概述2.类的表示法3.类与类之间的关系关联关系&#xff08;1&#xff09;单向关联&#xff08;2&#xff09;双向关联&#xff08;3&#xff09;…

opencv 入门一(显示一张图片)

头文件添加如下&#xff1a; 库目录添加如下&#xff1a; 依赖的库如下&#xff1a; #include <iostream> #include "opencv2/opencv.hpp" int main(int argc,char ** argv) { cv::Mat img cv::imread(argv[1], -1); if (img.empty()) return -1; …

Cesium 3DTiles数据格式详解

目录 0 引言1 3DTiles1.1 起源1.2 后缀类型及特点1.2.1 b3dm1.2.2 i3dm1.2.3 pnts1.2.4 cmpt1.2.5 json1.2.6 总结 &#x1f64b;‍♂️ 作者&#xff1a;海码007&#x1f4dc; 专栏&#xff1a;CesiumforUnreal专栏&#x1f4a5; 标题&#xff1a;Cesium 3DTiles数据格式详解❣…

[DNS网络] 网页无法打开、显示不全、加载卡顿缓慢 | 解决方案

[网络故障] 网页无法打开、显示不全、加载卡顿缓慢 | 解决方案 问题描述 最近&#xff0c;我在使用CSDN插件浏览 MOOC 网站时&#xff0c;遇到了一些网络故障。具体表现为&#xff1a; MOOC 中国大学慕课网&#xff1a;www.icourse163.org点击CSDN插件首页的 MOOC&#xff08…

【漏洞复现】CVE-2023-6895 IP网络对讲广播系统远程命令执行

漏洞描述 杭州海康威视数字技术有限公司IP网络对讲广播系统。 海康威视对讲广播系统3.0.3_20201113_RELEASE(HIK)存在漏洞。它已被宣布为关键。该漏洞影响文件/php/ping.php 的未知代码。使用输入 netstat -ano 操作参数 jsondata[ip] 会导致 os 命令注入。 开发语言:PHP 开…

无人机支持的空中无蜂窝大规模MIMO系统中上行链路分布式检测

无人机支持的空中无蜂窝大规模MIMO系统中上行链路分布式检测 无人机支持的空中无蜂窝大规模MIMO系统中上行链路分布式检测介绍题目一. 背景&#xff08;解决的问题&#xff09;二. 系统模型2.1 信道模型2.1.1 信道系数2.1.2 进行标准化 2.2 信道估计 和 数据传输2.2.1 信道估计…

大数据处理与分析-Spark

导论 (基于Hadoop的MapReduce的优缺点&#xff09; MapReduce是一个分布式运算程序的编程框架&#xff0c;是用户开发“基于Hadoop的数据分析应用”的核心框架 MapReduce是一种用于处理大规模数据集的编程模型和计算框架。它将数据处理过程分为两个主要阶段&#xff1a;Map阶…

Python算法例19 创建最大数

1. 问题描述 给定两个长度分别是m和n的数组&#xff0c;数组的每个元素都是数字0~9&#xff0c;从这两个数组当中选出k个数字来创建一个最大数&#xff0c;其中k满足k&#xff1c;mn&#xff0c;选出来的数字在创建最大数里的位置必须与在原数组内的相对位置一致。返回k个元素…

宝塔Linux面板计划任务:文件夹改名方式天天切割日志脚本

新手第一次操作&#xff0c;目测成功且完美&#xff0c;供大家参考 current_time$(date %Y%m%d%H%M%S) old_folder_name"/www/wwwlogs" new_folder_name"/www/wwwlogs_${current_time}" mv "$old_folder_name" "$new_folder_name" m…

layui 树组件tree 通过API获取数据

一、简单 var treedata[];tree.render({elem: #addLeftType,id: demoId,data: treedata,showCheckbox: true,oncheck: function(obj){console.log(obj.data); // 得到当前点击的节点数据console.log(obj.checked); // 节点是否被选中console.log(obj.elem); // 得到当前节点元素…

什么是数据仪表板?数据可视化仪表盘怎么制作?

在数据经济时代&#xff0c;分析数据是每个企业做出最佳决策的关键。但是&#xff0c;手动分析和解释大量数据是不可行的。数据可视化对于分析数据中存在的各种有价值信息至关重要&#xff0c;包括可见趋势和隐藏趋势等。仪表盘显示可视化趋势和信息&#xff0c;例如 KPI、趋势…

npm安装依赖报错ERESOLVE unable to resolve dependency tree(我是在taro项目中)(node、npm 版本问题)

换了电脑之后新电脑安装包出错 &#x1f447;&#x1f447;&#x1f447; npm install 安装包报错 ERESOLVE unable to resolve dependency tree 百度后尝试使用 npm install --force 还是报错 参考 有人说是 node 版本和 npm 版本的问题 参考 新电脑 node版本&#xff1a;16.1…

HackTheBox - Medium - Windows - Aero

Aero 这个机器利用了今年比较新的cve&#xff0c;关于windows11的漏洞&#xff0c;类似于lnk、scf&#xff0c;但这个危害更高&#xff0c;通过易受攻击的windows11 利用theme、msstyles来实现RCE. Aero 是一台中等难度的 Windows 机器&#xff0c;最近有两个 CVE&#xff1a;…

Apache Tomcat httpoxy 安全漏洞 CVE-2016-5388 已亲自复现

Apache Tomcat httpoxy 安全漏洞 CVE-2016-5388 已亲自复现 漏洞名称漏洞描述影响版本 漏洞复现环境搭建漏洞利用修复建议 总结 漏洞名称 漏洞描述 在Apache Tomcat中发现了一个被归类为关键的漏洞&#xff0c;该漏洞在8.5.4(Application Server Soft ware)以下。受影响的是组…

语音识别与人机交互:发展历程、挑战与未来前景

导言 语音识别技术作为人机交互领域的重要组成部分&#xff0c;近年来取得了巨大的发展。本文将深入研究语音识别与人机交互的发展历程、遇到的问题、解决过程、未来的可用范围&#xff0c;以及在各国的应用和未来的研究趋势。我们将探讨在这个领域&#xff0c;哪一方能取得竞争…

comfyUI + animateDiff video2video AI视频生成工作流介绍及实例

原文&#xff1a;comfyUI animateDiff video2video AI视频生成工作流介绍及实例 - 知乎 目录 收起 前言 准备工作环境 comfyUI相关及介绍 comfyUI安装 生成第一个视频 进一步生成更多视频 注意事项 保存为不同的格式 视频宽高设置 种子值设置 提示词与负向提示词…

如何将图片转为PDF

问题描述&#xff1a;如何将图片转为PDF&#xff0c;有时需要将纸质文档扫描成PDF&#xff0c;然后上传到网上。 解决办法&#xff1a;平时使用的方法是将图片插入到word文件中&#xff0c;然后将图片设置为浮于文字下方&#xff0c;然后调整图片的大小&#xff0c;铺满整个wo…

如何进一步优化Ubuntu服务器的性能

导读&#xff1a; 要进一步优化Ubuntu服务器的性能&#xff0c;您可以考虑以下几个方面&#xff1a;优化软件包管理&#xff1a; Ubuntu使用APT&#xff08;Advanced Package Tool&#xff09;作为其软件包管理工具。为了提高性能&#xff0c;您可以采取以下措施 要进一步优化U…

C# Tcplistener,Tcp服务端简易封装

文章目录 前言相关文章前言设计代码简单使用运行结果 前言 我最近有个需求要写Tcp服务端&#xff0c;我发现Tcp服务端的回调函数比较麻烦&#xff0c;简化Tcp的服务&#xff0c;我打算自己封装一个简单的Tcp服务端。 相关文章 C# TCP应用编程三 异步TCP应用编程 C# Tcpclient…