问题是我正在开发一个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块并将其保存到数据库。
答案 0 :(得分: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