DRF案例之车厂API

DRF案例之车厂API

目录

  • DRF案例之车厂API
    • 需求
    • urls.py
    • models.py
    • views.py
    • MySerializers.py
    • MyValidate.py
    • MyFilter.py
    • MyPagination.py
    • settings注册自定义类
    • 国际化输出

需求

  • 定义车型表(CarModel),车厂表(CarFactory),经销商表(Distributor)
  • 一个车厂可以生产多种车型
  • 一个经销商可以出售多种车型
  • 一个车型可以有多个经销商出售
  • 定义用户表,要求由django内置的user表扩写,新添mobile字段
  • 定义登录接口,要求使用jwt返回token,格式要求为{“status”:100, “msg”:“登录成功”, “token”:“…”}
  • token的过期时间为3天
  • 所有接口(除登录),必须登录后才能访问
  • 管理员登录后可以对车型车厂经销商三表进行增删改,群查,单查
  • 普通用户仅能使用查询车型、车厂,经销商和删除车型这几个接口
  • 所有查询接口都要有分页功能
  • 查询所有车型接口时可以按车型名字进行精准过滤

urls.py

from django.contrib import admin
from django.urls import path
from rest_framework_simplejwt.views import TokenObtainPairView
from rest_framework.routers import SimpleRouter
from car.views import CarModelView, CarFactoryView, DistributorView# 创建SimpleRouter实例并注册url, 这个步骤是用SimpleRouter自动生成路由
routers = SimpleRouter()
routers.register('CarModelView', CarModelView, 'CarModelView')
routers.register('CarFactoryView', CarFactoryView, 'CarFactoryView')
routers.register('DistributorView', DistributorView, 'DistributorView')
urlpatterns = [path('admin/', admin.site.urls),# 用simplejwt自带的模块帮我们创建登录接口,因此视图不再需要手写path('login/', TokenObtainPairView.as_view()),
]
# 将SimpleRouter创建的映射添加进路由
urlpatterns += routers.urls

models.py

from django.db import models
from django.contrib.auth.models import AbstractUserclass CarModel(models.Model):# 车型name = models.CharField(max_length=19, null=True)price = models.CharField(max_length=19, null=True)carFactory = models.ForeignKey(to='CarFactory', on_delete=models.CASCADE, null=True)distributor = models.ManyToManyField(to='Distributor', null=True)# 这两个方法是将车厂、经销商详情封装成字典和列表的序列化过程def carFactory_detail(self):return {'name': self.carFactory.name, 'addr': self.carFactory.addr, 'mobile': self.carFactory.mobile}def distributor_list(self):distributor_list = []for i in self.distributor.all():distributor_list.append({'name': i.name, 'addr': i.addr, 'mobile': i.mobile})return distributor_listclass CarFactory(models.Model):# 车厂name = models.CharField(max_length=19, null=True)addr = models.CharField(max_length=19, null=True)mobile = models.CharField(max_length=11, null=True)class Distributor(models.Model):# 经销商name = models.CharField(max_length=19, null=True)addr = models.CharField(max_length=19, null=True)mobile = models.CharField(max_length=11, null=True)class UserLog(AbstractUser):# 用户mobile = models.CharField(max_length=11, null=True)

settings注册用户表

AUTH_USER_MODEL = 'car.UserLog'

views.py

from rest_framework.viewsets import ViewSetMixin
from rest_framework.generics import ListCreateAPIView, DestroyAPIView, UpdateAPIView
from car.models import CarFactory, CarModel, Distributor
from car.MySerializers import CarModelSerializer, CarFactorySerializer, DistributorSerializer# 用viewsets的子类创建增删改查接口
class CarModelView(ViewSetMixin, ListCreateAPIView, DestroyAPIView, UpdateAPIView):queryset = CarModel.objects.all()serializer_class = CarModelSerializerclass CarFactoryView(ViewSetMixin, ListCreateAPIView, DestroyAPIView, UpdateAPIView):queryset = CarFactory.objects.all()serializer_class = CarFactorySerializerclass DistributorView(ViewSetMixin, ListCreateAPIView, DestroyAPIView, UpdateAPIView):queryset = Distributor.objects.all()serializer_class = DistributorSerializer

MySerializers.py

from rest_framework_simplejwt.serializers import TokenObtainPairSerializerfrom car.models import CarModel, CarFactory, Distributor, UserLog
from rest_framework import serializersclass CarModelSerializer(serializers.ModelSerializer):class Meta:model = CarModel# fields限定字段,将仅用于序列化的字段进行拆分fields = ['id', 'name', 'price', 'carFactory', 'distributor', 'carFactory_detail', 'distributor_list']extra_kwargs = {'id': {'read_only': True},'carFactory_detail': {'read_only': True},'distributor_list': {'read_only': True},}class CarFactorySerializer(serializers.ModelSerializer):class Meta:model = CarFactoryfields = '__all__'class DistributorSerializer(serializers.ModelSerializer):class Meta:model = Distributorfields = '__all__'class UserLogSerializer(serializers.ModelSerializer):class Meta:model = UserLogfields = '__all__'# 重写登录接口的序列化类,自定制返回格式
class CommonTokenObtainSerializer(TokenObtainPairSerializer):def validate(self, attrs):# 获取父类的元素,也就是默认的返回内容dic = super().validate(attrs)data = {'code': 100,'msg': '登录成功','username': self.user.username,'token': dic.get('access')}return data

MyValidate.py

重写权限类

from rest_framework.permissions import BasePermissionclass Permission(BasePermission):def has_permission(self, request, view):# 首先判断发送请求的是否为超级用户,如果是则直接返回if not request.user.is_superuser:# 如果请求的路由是'CarModelView'且为GET、DELETE请求则访问通过if view.basename == 'CarModelView' and request.method == 'DELETE' or request.method == 'GET':return Trueelse:return Falsereturn True

MyFilter.py

重写过滤类

from rest_framework.filters import BaseFilterBackendclass CommonFilter(BaseFilterBackend):def filter_queryset(self, request, queryset, view):# 精准查询# 示例:http://127.0.0.1:8000/car/?name=张三name = request.query_params.get('name', None)if name:queryset = queryset.filter(name__contains=name)return queryset

MyPagination.py

重写分页类

from rest_framework.pagination import PageNumberPagination# 1.基本分页
class CommonPageNumberPagination(PageNumberPagination):# 每页显示2条page_size = 2# http://127.0.0.1:8008/publish/?page=2  当前页数page_query_param = 'page'# http://127.0.0.1:8008/publish/?page=2&size=3 每页显示条数page_size_query_param = 'size'# 每页最多显示10条max_page_size = 10# 示例# http://127.0.0.1:8008/publish/?page=2 查询第二页,每页显示2条

settings注册自定义类

REST_FRAMEWORK = {# DRF默认权限类'DEFAULT_PERMISSION_CLASSES': ('car.MyValidate.Permission',),# DRF默认认证类'DEFAULT_AUTHENTICATION_CLASSES': ('rest_framework_simplejwt.authentication.JWTAuthentication',),# DRF默认分页类'DEFAULT_PAGINATION_CLASS': ('car.MyPagination.CommonPageNumberPagination'),# DRF默认过滤类'DEFAULT_FILTER_BACKENDS': ['car.MyFilter.CommonFilter'],}

国际化输出

让jwt和drf默认的返回信息变成中文

# settings.pyINSTALLED_APPS = ['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','car','rest_framework','rest_framework_simplejwt',
]LANGUAGE_CODE = 'zh-hans'TIME_ZONE = 'Asia/Shanghai'USE_I18N = TrueUSE_TZ = False

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

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

相关文章

做亚马逊店铺怎么解决网络问题?

在全球电商市场迅速崛起的背景下,亚马逊已成为众多商家拓展海外市场的首选平台。然而,网络问题始终困扰着亚马逊商家,若不能有效解决,不仅影响工作效率,更可能面临店铺被封禁的风险。本文将详细介绍亚马逊店铺运营遇到…

xgp加速器免费 微软商店xgp用什么加速器

2001年11月14日深夜,比尔盖茨亲自来到时代广场,在午夜时分将第一台Xbox交给了来自新泽西的20岁年轻人爱德华格拉克曼,后者在回忆中说:“比尔盖茨就是上帝。”性能超越顶级PC的Xbox让他们趋之若鹜。2000年3月10日,微软宣…

Vision Pro“裸眼上车”,商汤绝影全新舱内3D交互亮相

2023年,Apple Vision Pro的横空出世让人们领略到了3D交互的魅力,商汤绝影通过深厚的技术研发实力和高效的创新迭代效率,带来两大全新座舱3D交互:3D Gaze高精视线交互和3D动态手势交互。 作为全球首创的能够通过视线定位与屏幕图标…

C语言中整型与浮点型在内存中的存储

今天让我们来看看整型的数据和浮点型的数据在内存中是怎么存储的呢 整型数据在内存中的存储 整型数据在内存中存储的是二进制的补码 正数的话也没什么可说的,原码反码补码都相同 我们来看看负数: 以-5为例 原码:10000000 00000000 00000000 0…

传染病模型SIR及其变体(python版本)

文章目录 传染病模型及其变体1. SI模型1.1代码2. SIS模型2.1 代码3. 基本再生数 basic reproductive number4. SIR模型4.1 代码5. SEIR模型5.1 代码6. SEIJR模型6.1 代码7. SEIJRD模型7.1 代码传染病模型及其变体 1. SI模型 在该模型里面,群体中只有两种人:易感者和感染者。…

Postman之页面简介 V9.31.0

Postman之页面简介 V9.31.0 一、顶部栏二、左部栏三、中部栏四、下部栏 一、顶部栏 (1)new选项框,生成新建请求、集合、环境等 (2)import选项框,可以导入文件、文件夹、链接、文本信息等 (3&…

ros2_control【B站WMGIII教学学习记录】1

资源 https://www.bilibili.com/video/BV1ku411G7UR? 学习过程中存在bug,记录一下 1 Q:"package ‘joint_state_publisher_gui’ not found, searching: [/home A: sudo apt install ros-humble-joint-state-publisher2 https://fishros.org.cn/forum/to…

go语言并发实战——日志收集系统(八) go语言操作etcd以及利用watch实现对键值的监控

有关包的安装 我们要实现go语言对第三方包的操作需要我们下载第三方包go.etcd.io,下载命令: go get go.etcd.io/etcd/client/v3 ectd的put与get操作 相关函数说明与示例 我们想实现对etcd进行简单的操作的步骤还是比较简单的,在我上一篇文…

爬虫抓取网站数据

Fiddler 配置fiddler工具结合浏览器插件 配置fiddler Tools--Options 抓包技巧 谷歌浏览器开启无痕浏览,使用SwitchyOmega配置好代理端口 Ctrl x 清理所有请求记录,可以删除指定不需要日志方便观察 设置按请求顺序 观察cookie,观察请求hesder cookie和row返回结果 Swit…

【C语言】深入理解KMP算法及C语言实现

一、KMP算法简介 KMP算法(Knuth-Morris-Pratt算法)是一种高效的字符串匹配算法,由Donald Knuth、James H. Morris和 Vaughan Pratt共同发明。KMP算法的核心思想是当一次字符比较失败时,利用已经得到的部分匹配信息,将模…

vue-project-tree vue3 树形结构展示组件

GitHub:vue-project-tree by one-ccs Gitee:vue-project-tree by one-ccs 遵循 MIT 开源协议 文章目录 vue-project-tree一、使用二、API1、属性2、事件3、方法4、插槽 vue-project-tree 使用 Vue3 TS 实现的树形结构展示组件,有拖拽、排序…

服务器数据恢复—StorNext文件系统下raid5阵列数据恢复案例

服务器数据恢复环境: 昆腾某型号存储,8个存放数据的存储柜1个存放元数据的存储柜。 元数据存储:8组RAID1阵列1组RAID10阵列4个全局热备硬盘。 数据存储:32组RAID5阵列,划分2个存储系统。 服务器故障: 数据…

《QT实用小工具·四十一》无边框窗口

1、概述 源码放在文章末尾 该项目实现了无边框窗口效果&#xff0c;项目demo如下所示&#xff1a; 项目代码如下所示&#xff1a; #include "framelesswindow.h" #include <QGuiApplication> #include <QScreen>#ifdef Q_OS_WIN #include <window…

单例设计模式c++

什么是单例模式&#xff1f; 单例模式指在整个系统生命周期里&#xff0c;保证一个类只能产生一个实例&#xff0c;确保该类的唯一性。 单例模式分类 单例模式可以分为懒汉式和饿汉式&#xff0c;两者之间的区别在于创建实例的时间不同&#xff1a; 懒汉式&#xff1a;指系…

Mac 安装Nodejs

Nodejs介绍 简单的说 Node.js 就是运行在服务端的 JavaScript。 Node.js 是一个基于 Chrome JavaScript 运行时建立的一个平台。 Node.js 是一个事件驱动 I/O 服务端 JavaScript 环境&#xff0c;基于 Google 的 V8 引擎&#xff0c;V8 引擎执行 Javascript 的速度非常快&am…

带你走进不一样的策略模式

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 带你走进不一样的策略模式 前言策略模式简介概念解释 策略模式的结构策略模式优点项目实践之bean策略构思业务策略实现策略接口实现策略上下文业务实现 前言 在编程的世界里&#xff0c;每一次按键都…

刷代码随想录有感(46):平衡二叉树

这道题给我的教训&#xff1a;别轻视递归。 题干&#xff1a; 代码&#xff1a; int geiHeight(TreeNode* node){if(node NULL)return 0;int leftHeight getHeight(node -> left);if(leftHeight -1) return -1;int rightHeight getHeight(node -> right);if(rightH…

计算机网络基础认识

本篇文章是我在B站上看到关于计算机网络的介绍视频收到的启发。本篇文章的内容来自【网络】半小时看懂<计算机网络>_哔哩哔哩_bilibili 一、物理层 从常理来说&#xff0c;进行连个设备之间的通讯&#xff0c;首先最容易想到的就是使用一根线连接两个设备进行通讯。但是…

【MAC】删除自带的输入法

问题描述 平常使用mac办公&#xff0c;经常会非预期切换到自带的ABC输入法&#xff0c;令人很困惑。 解决方案&#xff1a; 1、下载PlistEdit Pro 链接&#xff1a;https://www.fatcatsoftware.com/plisteditpro/ 2、执行命令 sudo open ~/Library/Preferences/com.apple.…

手把手教会你做属于自己的网站《保姆级教程》

手把手教会你做属于自己的网站《保姆级教程》 前言开始教程特别说明下期内容预报 前言 什么是个人网站&#xff1f; 个人网站是指因特网上一块固定的面向全世界发布消息的地方&#xff0c;通常由域名&#xff08;也就是网站地址&#xff09;、程序和网站空间构成&#xff0c;并…