问题是我正在开发一个 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 块并将其保存到数据库中。