django图片上传与显示
时间: 2023-09-13 12:04:31 浏览: 115
Django实现后台上传并显示图片功能
4星 · 用户满意度95%
在 Django 中,实现图片上传和显示的方法如下:
1. 在 models.py 中定义一个字段来存储图片,例如:
```
from django.db import models
class MyModel(models.Model):
image = models.ImageField(upload_to='images/')
```
其中 upload_to 参数指定了上传文件的存储路径,相对于 MEDIA_ROOT。
2. 在 settings.py 中配置 MEDIA_ROOT 和 MEDIA_URL,例如:
```
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
MEDIA_URL = '/media/'
```
其中 MEDIA_ROOT 是上传文件的保存路径,MEDIA_URL 是上传文件的访问路径。
3. 在 urls.py 中配置 media 的访问地址,例如:
```
from django.conf import settings
from django.conf.urls.static import static
urlpatterns = [
# ...
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
```
4. 在模板中使用 `<img>` 标签来显示图片,例如:
```
<img src="{{ mymodel.image.url }}" alt="My Image">
```
其中 mymodel 是 MyModel 的实例。
5. 在表单中使用 `<input type="file">` 标签来上传图片,例如:
```
<form method="post" enctype="multipart/form-data">
{% csrf_token %}
<input type="file" name="image">
<button type="submit">Submit</button>
</form>
```
其中 enctype="multipart/form-data" 是必须的,否则上传的文件会被视为普通的文本数据。在视图函数中,可以通过 request.FILES 来获取上传的文件,例如:
```
def my_view(request):
if request.method == 'POST':
form = MyForm(request.POST, request.FILES)
if form.is_valid():
mymodel = form.save()
# ...
else:
form = MyForm()
return render(request, 'my_template.html', {'form': form})
```
其中 MyForm 是一个 ModelForm,例如:
```
from django import forms
from .models import MyModel
class MyForm(forms.ModelForm):
class Meta:
model = MyModel
fields = ['image']
```
阅读全文