django_cms ImproperlyConfigured:导入中间件cms.middleware.media时出错

时间:2010-11-02 22:25:39

标签: django django-cms

我正在将一个使用django_cms的应用程序从一个服务器上移动到另一个服务器,并且花了最后4个小时试图查找此错误的原因。建议非常欢迎!

 mod_wsgi (pid=21972): Exception occurred within WSGI script '/var/www/vhosts/compdoctest.com/django/compdoc/django.wsgi'.
 Traceback (most recent call last):
   File "/usr/lib/python2.5/site-packages/django/core/handlers/wsgi.py", line 230, in __call__
     self.load_middleware()
   File "/usr/lib/python2.5/site-packages/django/core/handlers/base.py", line 42, in load_middleware
     raise exceptions.ImproperlyConfigured('Error importing middleware %s: "%s"' % (mw_module, e))
 ImproperlyConfigured: Error importing middleware cms.middleware.media: "No module named media"

违规行是settings.py

中的中间件列表中的最后一行
MIDDLEWARE_CLASSES = (
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'cms.middleware.page.CurrentPageMiddleware',
    'cms.middleware.user.CurrentUserMiddleware',
    'cms.middleware.multilingual.MultilingualURLMiddleware',
    'cms.middleware.media.PlaceholderMediaMiddleware',
    )

如果我删除了最后一行,那么代码会继续并且稍后会说中间件中需要该项目。

我使用的是稍微不同的django版本,旧工作服务器上的1.2.1 final和新服务器上的1.2.3 final。

我尝试过的所有事情:

  • 旧服务器上使用的相同版本的django_cms - 2.1.0 beta 3
  • github上的最新版本 - 2.1.0.beta2-550将cms,mptt,菜单,发布者文件夹放入
  • app来自python导入
  • 用Google搜索(没有人遇到我能找到的同样问题)
  • 直接
  • 中间件文件(没问题)

在python中打开的结果:

python manage.py shell        
Python 2.5.2 (r252:60911, Jan 20 2010, 23:14:04) 
[GCC 4.2.4 (Ubuntu 4.2.4-1ubuntu3)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
(InteractiveConsole)
>>> import cms.middleware.media
>>> cms.middleware.media.__file__
'/var/www/vhosts/compdoctest.com/django/compdoc/cms/middleware/media.pyc'
>>> from django.forms.widgets import Media
>>> import cms.middleware.media
>>> 

2 个答案:

答案 0 :(得分:4)

感谢我的朋友Bartosz Ptaszynski指出我正确的方向。这是一个路径问题。将它添加到settings.py文件的顶部,这一切都神奇地开始工作。

sys.path.insert(0,'/ path_to_app / app /')

他指出:

WSGI脚本中发生异常意味着在Web服务器下运行时的路径是错误的,这是一个与manage.py shell完全不同的环境

答案 1 :(得分:0)

我遇到了同样的问题。但由于它只在使用mod_wsgi时发生,另一种解决方案是在apache配置中添加路径(而不是在setting.py中编辑syspath):

    # mod_wsgi settings
WSGIDaemonProcess name user=user group=group python-path=/app_path/app/:/app_path/lib/python2.6/site-packages/:/app_path/
WSGIProcessGroup polykum

Jon Black的示例中也提供了包含路径中的站点包。