问题是,我正在做一个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块并将其保存到数据库。
发布于 2013-01-31 05:39:27
有很多方法可以实现你所需要的。
我要做的就是将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
https://stackoverflow.com/questions/14613752
复制相似问题