Django + Apache + mod_wsgi =错误请求(400)

时间:2014-01-27 14:55:07

标签: python django apache mod-wsgi bad-request

我正试图以Debug=True模式在VPS上启动我的应用。

我正在使用Django 1.6和Python 2.7。

我尝试过简单的wscgi 脚本,发现它运行良好(基本上返回200和文本/ plain中的“Hello world”) 到浏览器。这是我的配置:

虚拟主机配置

<VirtualHost *:80>
ServerName subdomain.domain.info
ServerAlias www.subdomain.sigizmund.info
WSGIScriptAlias / /var/www/subdomain/index.wsgi
Alias /static/ /var/www/subdomain/static/
ErrorLog /tmp/subdomain.error.log
CustomLog /tmp/subdomain.custom.log common
LogLevel debug
<Location "/static/">
  Options -Indexes
</Location>
<Directory /home/sgzmd/code/myproject>
  Order deny,allow
  Allow from all
</Directory>
</VirtualHost>

index.wsgi

import os
import sys
import site

# Add the site-packages of the chosen virtualenv to work with
site.addsitedir('/home/sgzmd/.virtualenvs/myenv/local/lib/python2.7/site-packages')

PROJECT_PATH = '/home/sgzmd/code/myproject'
if PROJECT_PATH not in sys.path:
    sys.path.insert(0, PROJECT_PATH)

os.environ['DJANGO_SETTINGS_MODULE'] = 'myproject.settings'

# Activate your virtual env
activate_env=os.path.expanduser("~/.virtualenvs/myenv/bin/activate_this.py")
execfile(activate_env, dict(__file__=activate_env))

import django.core.handlers.wsgi
import cStringIO

import pprint

class LoggingMiddleware:

    def __init__(self, application):
        self.__application = application

    def __call__(self, environ, start_response):
        errors = environ['wsgi.errors']
        pprint.pprint(('REQUEST', environ), stream=errors)

        def _start_response(status, headers, *args):
            pprint.pprint(('RESPONSE', status, headers), stream=errors)
            return start_response(status, headers, *args)

        return self.__application(environ, _start_response)

application = LoggingMiddleware(django.core.handlers.wsgi.WSGIHandler())

我有以下日志记录输出:http://pastebin.com/SnZVEeT1(来自LoggingMiddleware)和/var/log/django/error.log正在创建和重新创建时,仍然完全为空。

我想通过编辑项目的settings.py来加载应用,其中的内容可以在这里找到:http://pastebin.com/Byr8RStb

感谢任何指针和想法,因为我现在基本上没有选择。

1 个答案:

答案 0 :(得分:0)

这不适用于开始:

activate_env=os.path.expanduser("~/.virtualenvs/myenv/bin/activate_this.py")

这是因为Apache以特殊用户身份运行,并且〜不会扩展到您自己设置virtualenv的用户。

不知道这是否相关。