24

我正在使用 django-compressor 和 django-staticfiles(外部版本,我在 Django 1.2 上)。

当我尝试加载我的网站时,出现错误:

TemplateSyntaxError: Caught UncompressableFileError while rendering: 'css/facebox.css' isn't accesible via COMPRESS_URL ('/static/') and can't be compressed

我已经验证COMPRESS_URL等于STATIC_URL,并且该文件实际上可以通过该 URL 访问。

查看 django-compressor 代码,我发现抛出异常的位置:

 def get_basename(self, url):
        try:
            base_url = self.storage.base_url
        except AttributeError:
            base_url = settings.COMPRESS_URL
        # I added the following print statement:
        print "url: %s, base_url: %s" % (url, base_url)
        if not url.startswith(base_url):
            raise UncompressableFileError("'%s' isn't accesible via "
                                          "COMPRESS_URL ('%s') and can't be "
                                          "compressed" % (url, base_url))

我的模板中的第一个{% compress css %}块是这样的:

{% compress css %}
<link rel="stylesheet" href="/static/css/blueprint/screen.css" type="text/css" />
<link rel="stylesheet" type="text/css" href="{{ STATIC_URL }}css/facebox.css" />
{% endcompress %}

(请注意,第一个链接不使用{{ STATIC_URL }},但第二个使用)

我在我的错误日志中得到了这个:

[Thu Oct 13 08:19:13 2011] [error] url: /static/css/blueprint/screen.css, base_url: /static/
[Thu Oct 13 08:19:13 2011] [error] url: /static/css/facebox.css, base_url: /static/
[Thu Oct 13 08:19:14 2011] [error] url: /static/css/blueprint/screen.css, base_url: /static/
[Thu Oct 13 08:19:14 2011] [error] url: css/facebox.css, base_url: /static/

如您所见,screen.css 文件被处理了两次,第二次成功。然而,facebox.css 文件第二次失败,可能是因为在{{ STATIC_URL }}第二次解析文件时没有在模板上下文中定义。

显然我可以通过不使用来解决问题{{ STATIC_URL }},但这不是一个可接受的解决方案。

为什么我的 css 文件会被处理两次?他们最初有media='screen, projection',但我认为这是导致问题的原因。

相关设置:

In [4]: from compressor.conf import settings

In [5]: settings.COMPRESS_ROOT
Out[5]: '/home/ianchat/static_files'

In [6]: settings.STATIC_ROOT
Out[6]: '/home/ianchat/static_files'

In [7]: settings.COMPRESS_URL
Out[7]: '/static/'

In [8]: settings.STATIC_URL
Out[8]: '/static/'

In [9]: settings.COMPRESS_OUTPUT_DIR
Out[9]: 'CACHE'

In [10]: settings.COMPRESS_CSS_FILTERS
Out[10]: ['compressor.filters.csstidy.CSSTidyFilter']

In [11]: settings.STATICFILES_FINDERS
Out[11]: 
('staticfiles.finders.FileSystemFinder',
 'staticfiles.finders.AppDirectoriesFinder',
 'staticfiles.finders.LegacyAppDirectoriesFinder',
 'compressor.finders.CompressorFinder')
4

5 回答 5

7

我遇到了同样的问题。

答案在这里找到:https ://github.com/jezdez/django_compressor/pull/206 该链接的解决方案是做handler500。我决定更改 500.html 模板以避免其中包含任何 {{STATIC_URL}},问题就解决了。

于 2012-06-24T19:41:24.070 回答
1

几乎看起来 STATIC_URL 不在您的上下文中。您确实配置了静态文件上下文处理器,对吗?您是否尝试过喜欢没有压缩器标签的文件?加载时 {{ STATIC_URL }} 是否正确显示在页面中?

我认为压缩器会检查 url,即使它通过查看https://github.com/jezdez/django_compressor/blob/develop/compressor/base.py#L57的文件系统访问它

于 2011-10-22T20:48:52.053 回答
1

这是一个老问题,但是在搜索此错误消息时为数不多的搜索结果之一,因此可能值得分享我的解决方案。

就我而言,这是一个非常简单的案例:我硬编码了我的静态 url,/但一开始就忘记了。所以我有这个:

<link type="text/css" rel="stylesheet" href="static/style.css" />

这给了我错误。改成这样后:

<link type="text/css" rel="stylesheet" href="/static/style.css" />

它是固定的。当然,我后来意识到,我应该使用设置 STATIC_URL:

<link type="text/css" rel="stylesheet" href="{{ STATIC_URL }}style.css" />

希望这对任何人都有帮助。

于 2013-06-15T23:12:43.350 回答
0

我又看了一些,我很确定异常是由于尝试显示未捕获的错误页面而没有第一遍的完整上下文引起的。这会导致 django-compressor 中的异常。 [1]

当然,解决方案是处理所有错误。

[1] 我也在运行一些非标准代码来显示静态页面,这可能会干扰并且该错误不太常见的原因。

于 2011-12-28T14:39:14.573 回答
0

我遇到了同样的问题;在我的情况下,问题是由使用引起的COMPRESS_OFFLINE_CONTEXT- 它不是.update()上下文,而是完全替换它,因此删除了STATIC_URL. 在我的情况下,解决方案只是在 local_settings 导入之后将其添加回COMPRESS_OFFLINE_CONTEXT,否则任何覆盖都不会起作用。

于 2015-12-08T10:08:47.277 回答