虽然通过服务器上存在的图像通过我的生产管理界面上传,但找不到,它在开发中可以很好地加载。我使用Django Image-kit调整上传图像的大小。
该图片未显示在网站上,如果我遵循图片的网址,则会显示
<h1>Not Found</h1>
<p>The requested URL /media/CACHE/images/references/<reference-name>/<image-name>/211b0022f8a2baad7cdc527711dcb.jpg was not found on this server.</p>
上传的图像未添加到我的静态文件中,这些文件已正确显示。
我的模型如下:
def generate_unique_slug(instance, field):
original = slugify(field)
unique = original
numb = 1
while instance.objects.filter(slug=unique).exists():
unique = f'{original}-{numb}'
numb += 1
return unique
def reference_main_image_path(instance, filename):
sub_folder = instance.slug
return f'references/{sub_folder}/{filename}'
class Reference(models.Model):
title = models.CharField(max_length=60)
description = models.TextField(max_length=2000)
slug = models.SlugField(max_length=12, unique=True, blank=True)
main_image = models.ImageField(
upload_to=reference_main_image_path, default='default.png')
main_thumbnail = ImageSpecField(source='main_image',
processors=[ResizeToFill(540, 300)],
format='JPEG',
options={'quality': 80},)
tags = TaggableManager()
def __str__(self):
return self.title
def save(self, *args, **kwargs):
if self.slug:
if slugify(self.title) != self.slug:
self.slug = generate_unique_slug(Reference, self.title)
else:
self.slug = generate_unique_slug(Reference, self.title)
super().save(*args, **kwargs)
我的view.py
:
def reference(request):
context = {
'references': Reference.objects.all(),
}
return render(request, 'home/references.html', context)
在“ html”代码中,我将“图像”称为“
”<img src="{{ reference.main_thumbnail.url }}">
我的settings.py
静态和媒体变量如下所示:
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
STATIC_URL = '/static/'
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
MEDIA_URL = '/media/'
我已经跑过manage.py collectstatic
我的upload_to
是否应该更改?或者如何告诉Django在“收集静态”时查看文件夹,然后将html更改为在静态文件夹中查找?
我觉得很奇怪,image-kit的文档应该只涉及“开发”,还是我缺少什么?
谢谢!
编辑:我在生产中使用了gunicorn和Nginx,但如上所述,我的静态文件er加载得很好。
编辑2: Nginx conf:
server {
server_name <server_names>;
location = /favicon.ico { access_log off; log_not_found off; }
location /static/ {
root /home/<user>/projects/<project>/<project>;
}
location / {
include proxy_params;
proxy_pass http://unix:/run/gunicorn.sock;
}
}
我遗漏了一些certbot SSL配置。
编辑3:urls.py
:
from django.urls import path
from . import views
from django.conf.urls.static import static
from django.conf import settings
urlpatterns = [
path('', views.home, name='home'),
path('ydelser/', views.service, name='service'),
path('referencer/', views.reference, name='reference'),
path('kontakt/', views.contact, name='contact'),
]
urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
答案 0 :(得分:1)
要使用nginx投放媒体文件,您应添加类似于static
的适当位置:
location /static/ {
root /home/<user>/projects/<project>/<project>;
}
location /media/ {
root /home/<user>/projects/<project>/<project>;
}
就像您在Django中所做的一样:
...
STATIC_URL = '/static/'
...
MEDIA_URL = '/media/'
但是,如果您不想使用nginx来提供媒体文件(推荐),而仍然想要使用django来提供媒体文件(不推荐),那么请确保该行
urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
在DEBUG = False时启用。
请注意,您不应将 media 文件视为静态-它们在逻辑上是不同的。虽然静态文件属于您的解决方案/项目并随其一起提供,但媒体文件不属于您的项目,通常由用户制作。
ps
如果您已将某些文件上传到本地网站上,则它们的位置如下:
def reference_main_image_path(instance, filename):
sub_folder = instance.slug
return f'references/{sub_folder}/{filename}'
class Reference(models.Model):
...
main_image = models.ImageField(
upload_to=reference_main_image_path, default='default.png')
如果您没有将它们(位于上面配置的文件夹中位于硬盘驱动器上的文件)复制到产品服务器-它们将不会显示。如果需要,请手动复制它们,然后将目标文件夹与nginx位置匹配。