私はこれで何時間も輪になって回っています。profile_picImageField
を持つUserProfileモデルがあります。ユーザーの写真を保存して表示したいのですが、何も機能しません。私はドキュメント、SO、グーグルを調べましたが、結果はありませんでした。
写真をアップロードしましたが、URLがデータベースに保存されていることがわかります。これは私が持っているものです:
# models.py
class UserProfile(models.Model):
...
title = models.CharField()
about_me = models.CharField()
profile_pic = models.ImageField(upload_to=content_file_name, blank=True)
# views.py
def user_details(request):
if request.method == 'POST':
form = UserProfileForm(request.POST, request.FILES, instance=request.user.get_profile())
if form.is_valid():
form.save()
return HttpResponseRedirect('/')
else:
form = UserProfileForm(instance=request.user.get_profile())
return render_to_response('user_details.html',
{'user': request.user, 'form': form},
context_instance=RequestContext(request))
# user_details.html
{% for field in form %}
{% if field.name != "profile_pic" %}
<!-- display regular fields -->
{{ field.label_tag }}{{ field }}
{% else %}
<!-- display the user photo -->
<img src="{{ MEDIA_URL }}{{ field.url }}" />
{% endif %}
{% endfor %}
レンダリングされたHTMLのソースを表示すると、表示されるのはMEDIA_URL(つまり、「media /」)だけですが、写真のURLは表示されません。{{field.url}}を{{field}}に置き換えると、「Currently」というラベル、「Clear」チェックボックス、画像を変更するオプションが付いたURLが表示されます。しかし、画像自体は見えません。
誰かが私が間違っていることを提案できますか?