Reputation: 325
Could you please help me to get image upload working on a view with django forms?
class User_Profile(models.Model):
user = models.OneToOneField(User, unique=True, related_name='profile')
photo = models.ImageField(upload_to = 'profiles/', null=True, blank=True)
class ProfileForm(forms.ModelForm):
class Meta:
model = User_Profile
exclude = ('user')
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"
Upvotes: 9
Views: 17208
Reputation: 61121
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']
Upvotes: 3
Reputation: 599956
You don't seem to be binding the file data to the form.
profile_form = ProfileForm(request.POST, request.FILES, instance=request.user.profile)
Upvotes: 16
Reputation: 1432
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.
Upvotes: 7