我正在做一个django网站,用户可以上传图像,我想使用sorl缩略图生成和缓存。我在一个fedora silverblue主机上使用了一个基于容器的工作流,使用的是podman。
我已经设置了memcached缓存引擎(使用memcached docker镜像),并且可以毫无问题地在django-shell中设置和获取缓存中的值。我运行了迁移命令,并将sorl缩略图添加到我的已安装应用程序中。我已经运行了./manage.py createcachetable命令,并且没有错误。我使用pylibmc:
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache',
'LOCATION': '127.0.0.1:11211',
}
}我已经创建了一个具有sorl.thumbnail ImageField的模型,尽管我希望最终使用标准的图像场,我相信这是可能的。
我有以下模型、视图和模板:
模型..。
class Image(models.Model):
image_file = ImageField(upload_to=user_directory_path)
#thumbnail = models.ImageField(upload_to=str(user_directory_path) + '_thumb', null=True)
userprofile = models.ForeignKey(ForumProfile, on_delete=models.CASCADE, related_name="images")查看...( get函数是在调试此问题时添加的)...
class ForumProfileUploadView(LoginRequiredMixin, FormView):
form_class = ImageForm
template_name = 'list.html'
success_url = reverse_lazy('my-view')
def get(self, request, *args, **kwargs):
form = self.form_class()
message = 'Hi!'
images = Image.objects.all()
context = {'images': images, 'form': form, 'message': message}
return render(self.request, 'list.html', context)
def form_valid(self, form):
obj = form.save(commit=False)
obj.userprofile = self.request.user.profile.forumprofile
# img = PillowImage.open(obj.image_file.file)
# obj.thumbnail = MakeThumbnail(self.request.FILES['image_file'])
# breakpoint()
obj.save()
message = 'Success!'
images = Image.objects.all()
breakpoint()
context = {'images': images, 'form': form, 'message': message}
return render(self.request, 'list.html', context)
def form_invalid(self, form):
message = 'The form is not valid. Fix the following error:'
images = Image.objects.all()
context = {'images': images, 'form': form, 'message': message}
return render(self.request, 'list.html', context)模板...
<!DOCTYPE html>
<html lang='en'>
<head>
</head>
<body>
<!-- List of uploaded documents -->
{% block content %}
{% load thumbnail %}
{% if images %}
All images in the database:
{% for image in images %}
{% thumbnail image.image_file.url "100x100" as im %}
<img src="{{ im.url }}" width="{{ im.width }}" height="{{ im.height }}">
{% endthumbnail %}
{% endfor %}
{% else %}
<p>No images.</p>
{% endif %}
<!-- Upload form. Note enctype attribute! -->
<form action="{% url 'my-view' %}" method="post" enctype="multipart/form-data">
{% csrf_token %}
{{ message }}
<p>{{ form.non_field_errors }}</p>
<p>{{ form.image_file.label_tag }} {{ form.image_file.help_text }}</p>
<p>
{{ form.image_file.errors }}
{{ form.image_file }}
</p>
<p><input type="submit" value="Upload"/></p>
</form>
{% endblock content %}
</body>发布于 2021-02-05 21:09:11
我已经设法让它工作了。我相当确定,对我来说,必要的事情是将缓存设置为对整个站点有效,尽管我可以将其用于特定的视图,这允许sorl.thumbnail开始工作。https://docs.djangoproject.com/en/3.1/topics/cache/#the-per-site-cache
https://stackoverflow.com/questions/66055987
复制相似问题