Python imagefield模型形式的Django自定义验证(最大文件大小等)

Python imagefield模型形式的Django自定义验证(最大文件大小等),python,django,validation,modelform,imagefield,Python,Django,Validation,Modelform,Imagefield,我有一个模型表单,它有一个名为“banner”的imagefield,我正在尝试验证文件大小和尺寸,如果图像太大,则提供一个错误 以下是models.py: class Server(models.Model): id = models.AutoField("ID", primary_key=True, editable=False) servername = models.CharField("Server Name", max_length=20) ip = mode

我有一个模型表单,它有一个名为“banner”的imagefield,我正在尝试验证文件大小和尺寸,如果图像太大,则提供一个错误

以下是models.py:

class Server(models.Model):
    id = models.AutoField("ID", primary_key=True, editable=False)
    servername = models.CharField("Server Name", max_length=20)
    ip = models.CharField("IP Address", max_length=50)
    port = models.CharField("Port", max_length=5, default='25565')
    banner = models.ImageField("Banner", upload_to='banners', max_length=100)
    description = models.TextField("Description", blank=True, max_length=3000)
    rank = models.IntegerField(default=0)
    votes = models.IntegerField(default=0)
    website = models.URLField("Website URL", max_length=200, blank=True)
    user = models.ForeignKey(User)
    motd = models.CharField("MOTD", max_length=150, default='n/a')
    playersonline = models.CharField("Online Players", max_length=7, default='n/a')
    online = models.BooleanField("Online", default=False)
    sponsored = models.BooleanField("Sponsored", default=False)
    lastquery = models.DateTimeField('Last Queried', auto_now=True)
    slugurl = models.SlugField("SlugURL", max_length=50)
    def __unicode__(self):
        return "%s (%s:%s)" % (self.servername, self.ip, self.port)
以下是带有自定义验证的forms.py:

class AddServer(ModelForm):
    class Meta:
        model = Server
        fields = ('servername', 'ip', 'port', 'website', 'description', 'banner')

     # Add some custom validation to our image field
    def clean_image(self):
        image = self.cleaned_data.get('banner', False)
        if image:
            if image._size > 1*1024*1024:
                raise ValidationError("Image file too large ( maximum 1mb )")
            if image._height > 60 or image._width > 468:
                raise ValidationError("Image dimensions too large ( maximum 468x60 pixels )")
            return image
        else:
            raise ValidationError("Couldn't read uploaded image")
据我所知,这应该是工作,但图像只是上传,无论大小


我是做错了什么,还是有更好的方法来做这件事?

请记录在案:


海报没有检查
表单.cleaned_data()
,这意味着
clean_xxx
验证没有运行。

方法的名称应该是
clean_
,在本例中为
clean_横幅

为了将来的参考,我将放置一段我在最近的一个项目中使用的代码(名称必须进行调整以使用OP代码):


看起来你的加薪没有被执行。检查if条件是否为真。(在your views.py中,您实际上是在检查数据)谢谢!原来我忘了检查数据了!facepalmimage.\u高度和图像。\u宽度似乎不存在?我发现:从django.core.files.images导入get_image_维度,这对我来说似乎更好。是的,我不知道我是怎么错过的。谢谢你的帮助。
from PIL import Image
from django.utils.translation import ugettext as _

def clean_photo(self):
    image = self.cleaned_data.get('photo', False)

    if image:
        img = Image.open(image)
        w, h = img.size

        #validate dimensions
        max_width = max_height = 500
        if w > max_width or h > max_height:
            raise forms.ValidationError(
                _('Please use an image that is smaller or equal to '
                  '%s x %s pixels.' % (max_width, max_height)))

        #validate content type
        main, sub = image.content_type.split('/')
        if not (main == 'image' and sub.lower() in ['jpeg', 'pjpeg', 'png', 'jpg']):
            raise forms.ValidationError(_('Please use a JPEG or PNG image.'))

        #validate file size
        if len(image) > (1 * 1024 * 1024):
            raise forms.ValidationError(_('Image file too large ( maximum 1mb )'))
    else:
        raise forms.ValidationError(_("Couldn't read uploaded image"))
    return image