9

Could you please help me to get image upload working on a view with django forms?

Models.py

class User_Profile(models.Model):
    user = models.OneToOneField(User, unique=True, related_name='profile')
    photo  = models.ImageField(upload_to = 'profiles/', null=True, blank=True)

Forms.py

class ProfileForm(forms.ModelForm):
        class Meta:
            model = User_Profile
            exclude = ('user')

Views.py

    if request.method == 'POST':
        profile_form = ProfileForm(request.POST, instance=request.user.profile)

        if profile_form.is_valid():
            profile_form.save()
            return HttpResponseRedirect('/panel/correct/')

    else:
        profile_form = ProfileForm(instance=request.user.profile)

My html form already contains enctype="multipart/form-data"

Alex Santos
  • 325
  • 1
  • 5
  • 16

3 Answers3

16

You don't seem to be binding the file data to the form.

profile_form = ProfileForm(request.POST, request.FILES, instance=request.user.profile) 
Daniel Roseman
  • 588,541
  • 66
  • 880
  • 895
  • 1
    Thanks, that was the problem... This is the first time I use Forms in Django... (not using django since 0.96 without newforms) – Alex Santos Jul 04 '09 at 19:17
7

Why not use the django-avatar project (I'm assuming you are thinking of adding user avatars to your project, based on the example)?

They have a pretty neat solution with an extra tag that resizes the image before displaying it first time. You store the original image and define the image sizes that you wish to accept on the website and the rest is done automagically for you.

michuk
  • 1,332
  • 1
  • 13
  • 19
3

This is just a matter of following the docs.

You are not using the correct form initialization in your post. In particular you are missing request.FILES parameter:

 form = ProfileForm(request.POST, request.FILES)

after the above the uploaded file can be retrieved from the FILES array:

 photo_file = request.FILES['photo']
Andriy Drozdyuk
  • 58,435
  • 50
  • 171
  • 272