Django admin CIDR类型

3 投票
1 回答
3053 浏览
提问于 2025-04-17 14:15

我正在做一个Django Admin项目,这个项目需要能够接受CIDR格式的数据,并把这些数据存入数据库(Postgres)。

假设我有一个模型:

##################################################
class CIDR(models.Model):
    ....
    net_cidr = models.IPAddressField(unique=True)
    ....

    def __unicode__(self):
        return self.net_cidr

##################################################

根据上面的代码,数据库中的net_cidr字段是inet类型,这种类型支持CIDR格式的数据。但是,IPAddressField不支持CIDR格式(至少对我来说是这样)。如果我想在管理网站上输入像“128.66.0.0/16”这样的内容,Django会弹出一个错误,告诉我“请输入一个有效的IPv4地址”。

我尝试把字段类型改成字符型(Char),这样是可以的(当然)。不过,把CIDR存成varchar在数据库里并不是个好主意。

我基本上想要的是让net_cidr能够接受一个IP范围,比如“128.66.0.0-128.66.255.255”或者一个CIDR块“128.66.0.0/16”,然后把它保存到数据库中,格式为“128.66.0.0/16”。

我认为关键在于如何让IPAddressField接受字符串类型的数据(比如IP范围或CIDR块)。然后我就可以把它转换成CIDR块并保存到数据库里。

1 个回答

1

有很多方法可以实现你需要的功能。

我会把 net_cidr 定义为 models.CharField,这是一种用来存储文本的字段。

接着,为你的模型定义一个表单,在这个表单里你可以实现 clean_net_cidr 这个函数。

class CIDRForm(ModelForm):
    def clean_net_cidr(self):
        # do your magic processing here

    class Meta:
        model = CIDR

然后把这个表单传递给模型的管理对象。

class CIDRAdmin(admin.ModelAdmin):
    form = CIDRForm

更新:

根据你的评论,这似乎正是你需要的。你可以查看这个链接:https://github.com/jimfunk/django-postgresql-netfields

这个库里除了其他字段外,还包括一个 CidrAddressField 字段。

撰写回答