2

问题是我正在开发一个 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能够接受一个I​​P范围,比如“128.66.0.0-128.66.255.255”或一个CIDR块“128.66.0.0/16”并将其保存到数据库中作为“128.66.0.0/16” .

我认为关键部分是如何让IPAddressField接受字符串类型(如 IP 范围或 CIDR 块)数据。然后我可以将其转换为 CIDR 块并将其保存到数据库中。

4

1 回答 1

1

有很多方法可以实现您所需要的。

我要做的是定义net_cidrmodels.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

于 2013-01-30T21:39:27.363 回答