gpt4 book ai didi

python - Django 1.1.1 : How should I store an empty IP address using PostgreSQL?

转载 作者:行者123 更新时间:2023-11-28 16:54:46 26 4
gpt4 key购买 nike

我正在编写一个 Django 应用程序,它存储带有可选路由信息的 IP 地址。我创建的 IP 模型的字段之一是 nexthop(用于下一跳路由),它通常为空。本来打算用MySQL,现在项目需求改用PostgreSQL。

这是我的模型的精简版:

class IP(models.Model):
address = models.IPAddressField()
netmask = models.IPAddressField(default='255.255.255.255')
nexthop = models.IPAddressField(null=True, blank=True, default=None)
active = models.BooleanField('is active?', default=1)

因此,对于 MySQL,我没有遇到将 nexthop 字段留空的问题。但是,现在我将开发环境切换到 Postgres,我们遇到了 known issue in Django 1.1.1其中空白 IP 地址引发 DataError

invalid input syntax for type inet: ""
LINE 1: ...-14 13:07:29', 1, E'1.2.3.4', E'255.255.255.255', E'', true)
^

如您所见,它之所以失败,是因为它试图在该列仅接受 NULL 时插入一个空字符串。

我非常需要能够将这个字段留空,因为如果 IP 没有下一跳,那么它的行为就会改变。

除了手动破解 Django 代码(这是我最终的最后手段)之外,我还考虑过将下一跳默认为 255.255.255.255 并围绕它包装一些业务逻辑(即,如果下一跳是 255.255.255.255,请对待作为正常路线),但这感觉就像一个 hack。

我想知道是否有任何关于更好的方法的建议,不需要破解 Django 或编写 hacky 逻辑,或者是否有完全不同的方法可以满足我的要求。

提前致谢!

编辑:临时解决方案

暂时(作为插页式修复)我决定使用下一跳的哨兵值:

在模型中:

IP_NEXTHOP_SENTINEL = '255.255.255.255'
class IP(models.Model):
nexthop = models.IPAddressField(
null=True,
blank=True,
default=IP_NEXTHOP_SENTINEL,
help_text='Use %s to indicate no next-hop' % IP_NEXTHOP_SENTINEL
)

def save(self, *args, **kwargs):
## hack for Django #5622 (http://code.djangoproject.com/ticket/5622)
if self.nexthop and self.nexthop == IP_NEXTHOP_SENTINEL:
self.nexthop = None

概述:

在管理门户之外创建 IP 对象按预期工作,这就是为什么我在 nexthop 上保留了 null=True 参数 field 。唯一将 255.255.255.255 设置为下一跳的地方是通过管理门户,因此我决定重载 save() 以始终将哨兵替换为 None 会给我我想要的最终结果,而且感觉不太像 hack。

感谢您对此的投入!

最佳答案

如果您可以说服开发人员接受其中一个补丁,我会说只需运行 Django 的补丁副本,直到补丁版本落地。如果不是,那么正如您所建议的那样,即使它是一种 hack,也可能不会像您建议的那样仅使用哨兵值。您也可以只使用常规的 CharField 而不是 IPAddressField,但是您不得不自己维护验证逻辑。

关于python - Django 1.1.1 : How should I store an empty IP address using PostgreSQL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1862123/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com