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

相关推荐
szccyw010 小时前
PHP源码能否用二手服务器部署_老旧服务器性价比分析【方法】
jvm·数据库·python
m0_6138562916 小时前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
我的xiaodoujiao17 小时前
API 接口自动化测试详细图文教程学习系列16--项目实战演练3
python·学习·测试工具·pytest
ID_1800790547317 小时前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
时空系17 小时前
第10篇:继承扩展——面向对象编程进阶 python中文编程
开发语言·python·ai编程
CHANG_THE_WORLD18 小时前
python 批量终止进程exe
开发语言·python
古城小栈18 小时前
从 cargo-whero 库中,找到提升 rust 的契机
开发语言·后端·rust
liann11918 小时前
3.2_红队攻击框架--MITRE ATT&CK‌
python·网络协议·安全·网络安全·系统安全·信息与通信
云天AI实战派18 小时前
AI 智能体问题排查指南:ChatGPT、API 调用到 Agent 上线失灵的全流程修复手册
大数据·人工智能·python·chatgpt·aigc
keep one's resolveY19 小时前
SpringBoot实现重试机制的四种方案
java·spring boot·后端