python django实战开发序列化器的一个应用心得分享

需求:

查询的时候返回不包括SharePasswd 字段, 但是新增操作需要用到该字段

再不写多个model模型和序列化器的前提下实现

如果您在查询(GET 请求)时不希望返回 SharePasswd 字段,但在新增(POST 请求)时需要用到该字段,那么您可以在序列化器中处理这种差异。

首先,确保您的序列化器在新增操作中处理 SharePasswd 字段,您可以保留它在 fields 列表中。然后,对于查询操作,您可以重写序列化器的 to_representation 方法,在序列化模型实例为字典时排除 SharePasswd 字段。

废话不多说, 直接上干货代码:

 序列化器中关键代码如下:

from rest_framework import serializers
from exfile.sharefilesync.share_file_strategy_models import ShareFilePolicy


class ShareFileSerializer(serializers.ModelSerializer):
    """共享型文件同步 策略管理 """

    class Meta:  # 查询不返回SharePasswd, 但是新增又需要该列
        model = ShareFilePolicy
        fields = ('PolicyID', 'PolicyName', 'PolicySwich', 'PolicyLock', 'SyncMode', 'SynCFLOW', 'Protocol', 'SharePort',
                  'ShareHostIP', 'ShareName', 'ShareUser', 'SharePasswd', 'Priority', 'MountStatus')

    def to_representation(self, instance):
        # 调用父类的to_representation方法获取整个实例的序列化表示
        ret = super().to_representation(instance)
        # 检查请求的方法,如果是GET请求,则移除SharePasswd字段
        if self.context['request'].method == 'GET':
            ret.pop('SharePasswd', None)
        return ret

model模型中关键代码:

以上需求可以实现在查询get请求时, 查询结果返回列布包扣sharePasswd字段, 通过postman调用显示如下:

下面通过postman执行新增操作

然后通过去数据库查看结果如下:

可以看到新增的时候SharePasswd又是能成功插入到数据库中的, 至此最上面的需求完美实现, 今天就先写到这, 后续更多实战开发技巧心得陆续更新, 谢谢您的关注!!1 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据结构 - 用队列实现栈/用栈实现队列

用栈实现队列 思路: 队列是遵循队头出数据,队列进数据。 创建两个栈,一个左栈,一个右栈。左栈用来插入新数据,右栈用来出数据 我们要借用栈的性质也实现一个出数据,和入数据的功能,该怎么样实…

[flask]异常抛出和捕获异常

Python学习之Flask全局异常处理流程_flask 异常处理-CSDN博客 读取文件错误 OSError: [Errno 22] Invalid argument:_[errno 22] invalid argument: ..\\data\\snli_1.0\\-CSDN博客 异常触发 assert触发异常: 在Python中,使用assert语句可以检查某个条…

“智慧食堂”设计与实现|Springboot+ Mysql+Vue+Java+ B/S结构(可运行源码+数据库+设计文档)

本项目包含可运行源码数据库LW,文末可获取本项目的所有资料。 推荐阅读100套最新项目持续更新中..... 2024年计算机毕业论文(设计)学生选题参考合集推荐收藏(包含Springboot、jsp、ssmvue等技术项目合集) 目录 1. 功…

Unity urp渲染管线下,动态修改材质球surfaceType

在项目中遇到了需要代码动态修改材质球的surfaceType,使其动态切换是否透明的需求。 urp渲染管线下,动态修改材质球的surfaceType,查了大部分帖子,都有一些瑕疵,可能会造成透明后阴影投射有问题。 其次在webgl平台上…

CSS(五)

一、定位 1.1 为什么需要定位 提问: 以下情况使用标准流或者浮动能实现吗? 1. 某个元素可以自由的在一个盒子内移动位置,并且压住其他盒子. 2. 当我们滚动窗口的时候,盒子是固定屏幕某个位置的。 以上效果,标准流或浮…

VBA高级应用30例应用2:MouseMove鼠标左键按下并移动鼠标事件

《VBA高级应用30例》(版权10178985),是我推出的第十套教程,教程是专门针对高级学员在学习VBA过程中提高路途上的案例展开,这套教程案例与理论结合,紧贴“实战”,并做“战术总结”,以…

数据安全之路:Databend 用户策略指南

在 Databend 中,我们致力于保护用户的数据安全。除了身份认证之外,我们还提供了多种访问策略,包括网络策略(Network Policy)、密码策略(Password Policy)和数据脱敏策略(Masking Pol…

【面试经典150 | 动态规划】三角形最小路径和

文章目录 写在前面Tag题目来源解题思路方法一:动态规划 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法,两到三天更新一篇文章,欢迎催更…… 专栏内容以分析题目为主,并附带一些对于本题涉及到的数据结构等内容进行…

如何使用Docker轻松构建和管理应用程序(二)

上一篇文章介绍了 Docker 基本概念,其中镜像、容器和 Dockerfile 。我们使用 Dockerfile 定义镜像,依赖镜像来运行容器,因此 Dockerfile 是镜像和容器的关键,Dockerfile 可以非常容易的定义镜像内容,同时在我们后期的微…

SpringBoot集成WebSocket实现简单的多人聊天室

上代码—gitee下载地址: https://gitee.com/bestwater/Spring-websocket.git下载代码,连上数据库执行SQL,就可以运行,最终效果

二轴机器人大米装箱机:高精度特性如何助力食品工业提升效率与品质?

在当今快节奏的工业生产中,食品行业的自动化、智能化水平已成为衡量其竞争力的关键指标。特别是在大米生产线上,如何确保装箱环节的高效与精准,直接关系到企业的生产效率和产品品质。二轴机器人大米装箱机凭借其高精度特性,正逐渐…

STM32的简介

内存 一般MCU包含的存储空间有FLASH和RAM,(RAM和flash又有片上和片外的区别,片上表示mcu自带的,已经封装在MCU内部的,片外表示外挂的,当项目中需要做一些复杂的应用,会存在资源不足的情况,这时…

动态菜单设计

需求: 登录不同用户 显示不同的菜单 思路:根据用户id 左关联表 查询出对应的菜单选项 查询SQL select distinct-- 菜单表 去除重复记录sys_menu.id,sys_menu.parentId, sys_menu.name from -- 权限表sys_menu-- 角色与权限表 菜单表id 角色菜…

Jenkins常用插件安装及全局配置

Jenkins常用插件安装及全局配置 前言 ​ Jenkins是一个流行的持续集成工具,通过安装适用的插件,可以扩展Jenkins的功能,并与其他工具和系统集成。本文将介绍一些常用的Jenkins插件以及安装和配置的步骤。通过安装和配置这些常用插件&#xf…

从根本上优雅地解决 VSCode 中的 Python 模块导入问题

整体概述: 在我尝试运行 test_deal_file.py 时,我遇到了一个 ModuleNotFoundError 错误,Python告诉我找不到名为 controllers 的模块。这意味着我无法从 deal_file.py 中导入 read_excel 函数。 为了解决这个问题,我尝试了几种方法…

【电能管理】电力物联网仪表/多功能电表/无线计量/多回路计量/分项计量/终端感知设备/全电量参数测量/正反向有功无功测量

什么是物联网电表!!! 安科瑞薛瑶瑶18701709087 物联网电表是智能电表的一种,可以用无线通信方式来操控,除了拥有电度表的有点以外,还可以把硬件和软件联合起来发挥更大的作用。 物联网电表主要用于计量低…

MySQL数据库(MySQL主从搭建|Django中实现MySQL读写分离|Django中使用MySQL连接池)

文章目录 一、MySQL主从搭建1.MySQL主从的目的?2.MySQL主从原理3.搭建步骤 二、Django中实现MySQL读写分离1.使用sqlite实现读写分离2.MySQL实现读写分离 三、Django中使用连接池1.使用池的目的2.Django中使用MySQL连接池 一、MySQL主从搭建 1.MySQL主从的目的&…

【数据分析面试】1. 计算年度收入百分比(SQL)

题目 你需要为公司的营收来源生成一份年度报告。计算截止目前为止,在表格中记录的第一年和最后一年所创造的总收入百分比。将百分比四舍五入到两位小数。 示例: 输入: annual_payments 表 列名类型amountINTEGERcreated_atDATETIMEstatusV…

通过PandasAI使用自然语言进行数据分析

通过PandasAI使用自然语言进行数据分析 介绍 ​ PandasAI是一个Python库,可以很容易地用自然语言向数据提问。它可以帮助您使用生成人工智能来探索、清理和分析数据。 使用PandasAI 这里使用Anaconda和Jupyter使用PandasAI 进入一个文件目录 创建一个 Notebook …

一个基于.NET Core构建的简单、跨平台、模块化的商城系统

商城后台管理端功能 商品:分类、品牌、单位、选项(销售属性)、属性、属性模板、属性组。 销售:订单、物流。 内容:首页配置、评论、回复。 配置:国家、用户、仓库、运费、高级设置。 系统:系…
最新文章