0

メディア ルートから提供しようとすると、この壊れたイメージが表示されます。ドキュメントへのリンクや以前の質問へのリンクを表示しないでください。私はそれらのことを試しましたが、私はまだこの壊れたイメージを得ています.

Models.py:

class BasicModel(models.Model):
    name = models.CharField(max_length=200)
    dob = models.DateField()
    photo = models.ImageField(upload_to='sample')

class BasicModelForm(ModelForm):
    class Meta:
            model = BasicModel

Views.py:

def BasicView(request):
    if request.method == 'POST':
            form = BasicModelForm(request.POST, request.FILES)
            if form.is_valid():
                    data = form.save()
                    return preview(request, data.id)
    else:
            form = BasicModelForm()
    return render_to_response("unnamed.html", {'form': form}, context_instance=RequestContext(request))

def preview(request, id):
    obj = get_object_or_404(BasicModel, pk=id)
    return render_to_response("preview.html", {'obj': obj})

設定.py:

MEDIA_ROOT = '/home/nirmal/try/files/'
MEDIA_URL = 'http://localhost:8000/files/'

Urls.py:

url(r'^unnamed/$', 'unnamed.views.BasicView'),
url(r'^files/(?P<path>.*)$', 'django.views.static.serve', {'document_root': settings.MEDIA_ROOT}),

Preview.html:

<html>
<body>
{{ obj.name }}
{{ obj.dob }}
<img src="{{ MEDIA_URL }}sample/{{ obj.photo }}" />
</body>
</html>

誰かがこれについて私を助けることができますか?

ありがとう!

4

2 に答える 2

2

交換:

{{ MEDIA_URL }}sample/{{ obj.photo }}

と:

{{ object.photo.url }}

ちなみに、{{MEDIA_URL}}もテンプレートで定義されていますか?

于 2012-03-01T17:25:48.953 に答える
1

ImageField 表現は に相対する URL を返すことを覚えていると思いますMEDIA_URL。つまり、テンプレートで次のコードを使用する必要があります。

<html>
<body>
{{ obj.name }}
{{ obj.dob }}
<img src="{{ MEDIA_URL }}{{ obj.photo }}" />
</body>
</html>

またはさらに短く、絶対 URL パスを次のように使用します。

<html>
<body>
{{ obj.name }}
{{ obj.dob }}
<img src="{{ obj.photo.url }}" />
</body>
</html>

ヒント、ブラウザで壊れた画像の URL を調べてください。のようなものだと思いhttp://localhost:8000/files/sample/sample/xyz.pngます。

于 2012-03-01T17:27:35.240 に答える