1

最初に「ログイン」ボタンを押すと、django admin へのログインに失敗しますが、「戻る」と「ログイン」をもう一度押すと、ユーザーが正常にログインします。

ここで zc.buildout を使用して Django アプリをデプロイしています。セットアップは、ここで説明されているものと同様ですhttp://www.meppum.com/2009/jan/17/installing-django-ubuntu-intrepid/。Nginx (127.0.0.1:8003 でリッスン) は Apache (127.0.0.1:8001 でリッスン) を超えて実行されており、両方のサーバーの構成は投稿の最後に記載されています。django アプリに 127.0.0.1:8003/ としてアクセスしています。

したがって、 127.0.0.1:8003/admin/ は django 管理者ログイン フォームを開きます。1)ユーザー名/パスを入力し、「ログイン」を押すと、(何らかの理由で)127.0.0.1 / adminにリダイレクトされ、80ポートでリッスンするサーバーがないため、何も終了しません。HTTP トレース (ログインをクリックした後: http://127.0.0.1:8003/admin/ )

POST /admin/ HTTP/1.1
Host: 127.0.0.1:8003
User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.17) Gecko/2010010604 Ubuntu/9.04 (jaunty) Firefox/3.0.17
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-us,en;q=0.5
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive: 300
Connection: keep-alive
Referer: http://127.0.0.1:8003/admin/
Cookie: JSESSIONID=0D287C17FBA82223AB7D5884EA534967; sessionid=c65c7af8ebde9e6bdf9c739a731d376b
Content-Type: application/x-www-form-urlencoded
Content-Length: 55
username=to&password=password&this_is_the_login_form=1

HTTP/1.x 302 FOUND
Server: nginx/0.8.29
Date: Mon, 01 Feb 2010 10:27:44 GMT
Content-Type: text/html; charset=utf-8
Connection: keep-alive
Expires: Mon, 01 Feb 2010 10:27:44 GMT
Vary: Cookie
Etag: "d41d8cd98f00b204e9800998ecf8427e"
Cache-Control: max-age=0
Set-Cookie: sessionid=9db437da69c359136786696f90ba89f2; expires=Mon, 15-Feb-2010 10:27:44 GMT; Max-Age=1209600; Path=/
Last-Modified: Mon, 01 Feb 2010 10:27:44 GMT
Location: http://127.0.0.1/admin/
Content-Length: 0

2) ブラウザの戻るボタンを押して、もう一度「ログイン」ボタンを押す (またはブラウザの「戻る」ボタンと「更新」ボタンを押す) と、正常にログインします。HTTP トレース:

POST /admin/ HTTP/1.1
Host: 127.0.0.1:8003
User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.17) Gecko/2010010604 Ubuntu/9.04 (jaunty) Firefox/3.0.17
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-us,en;q=0.5
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive: 300
Connection: keep-alive
Referer: http://127.0.0.1:8003/admin/
Cookie: JSESSIONID=0D287C17FBA82223AB7D5884EA534967; sessionid=9db437da69c359136786696f90ba89f2
Content-Type: application/x-www-form-urlencoded
Content-Length: 55
username=to&password=password&this_is_the_login_form=1

HTTP/1.x 200 OK
Server: nginx/0.8.29
Date: Mon, 01 Feb 2010 10:52:02 GMT
Content-Type: text/html; charset=utf-8
Transfer-Encoding: chunked
Connection: keep-alive
Expires: Mon, 01 Feb 2010 10:52:02 GMT
Vary: Cookie
Etag: "3355a46fb32d7cb6ab21262c359d9eec"
Cache-Control: max-age=0
Last-Modified: Mon, 01 Feb 2010 10:52:02 GMT

それはクッキー関連の問題のようですが、問題の根本はApacheやnginxの設定にもあると思います。

管理者ログインフォームをすぐに機能させる方法はありますか?

乾杯!

PSconfig:

Apache vhost 構成:

<VirtualHost *:8001>

    <Directory /home/toinbis/Desktop/programming/project/runtime/
htdocs/django_wsgi/>
        Order deny,allow
        Allow from all
    </Directory>

    WSGIDaemonProcess tsd user=www-data group=www-data threads=25
    WSGIProcessGroup tsd

    WSGIScriptAlias / /home/toinbis/Desktop/programming/project/
runtime/htdocs/django_wsgi/djproject.wsgi

    LogLevel warn
    ErrorLog  /home/toinbis/Desktop/programming/project/runtime/logs/
apache_tsd_error.log
    CustomLog /home/toinbis/Desktop/programming/project/runtime/logs/
apache_tsd_access.log combined

    ServerName localhost
</VirtualHost>

nginx 構成:

daemon off;
#user www-data;
worker_processes  2;

error_log  /home/toinbis/Desktop/programming/project/runtime/logs/
nginx_general_error.log;
pid        /home/toinbis/Desktop/programming/project/runtime/var/pids/
nginx.pid;

events {
    worker_connections  1024;
    #server_names_hash_bucket_size: 128;

}

http {
    include       /home/toinbis/Desktop/programming/project/runtime/
etc/nginx_conf/mime.types;
    default_type  application/octet-stream;

    access_log  /home/toinbis/Desktop/programming/project/runtime/logs/
nginx_access.log;
    error_log   /home/toinbis/Desktop/programming/project/runtime/logs/
nginx_error.log;

    sendfile        on;
    tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  2;
    tcp_nodelay        on;

    server_names_hash_bucket_size 128;
    #server_name_hashes 128;
    gzip  on;
    gzip_comp_level 2;
    gzip_proxied any;
    gzip_disable "MSIE [1-6]\.(?!.*SV1)"; #iš ubuntu
    gzip_types text/plain text/css application/x-javascript text/xml
application/xml application/xml+rss text/javascript;

upstream backend {
  server 127.0.0.1:8001;

}

server {
            listen   8003;
            server_name localhost;

            error_log /home/toinbis/Desktop/programming/project/
runtime/logs/project_nginx_error.log;
            access_log /home/toinbis/Desktop/programming/project/
runtime/logs/project_nginx_access.log;

            location / {
                        proxy_pass  http://backend/;
                        include     /home/toinbis/Desktop/programming/
project/runtime/etc/nginx_conf/nginx_proxy_1.conf;
            }

            location  /media/ {
                        root /home/toinbis/Desktop/programming/project/
src/tsd/core/;
            }

}
}

乾杯、に

4

3 に答える 3

1

設定が正しくありません。Djangoは、ポート80で実行されていると考えています。最初のHTTP応答で次の行を見てください。

Location: http://127.0.0.1/admin/

残念ながら、なぜこれが起こるのか今は理解できません。このような場合は、関連するDjangoコードをデバッガーでステップスルーすることをお勧めします。

于 2010-02-01T11:21:55.120 に答える
1

@Eugene Morozov は問題の最終結果を指摘していますが、解決策はもっと深いところにあると思います。

返されるLocationヘッダーが正しくありません:

Location: http://127.0.0.1/admin/

これには明らかにポート番号がありません。残念ながら、これがどこから来ているのかを正確に判断するのは困難です。Nginx または Apache がLocationヘッダーを自動的に変更している可能性があります。問題が発生する場所を確認するには、次のことをお勧めします。

  • ログインするたびに Cookie を消去してください。そうしないと、誤検知が発生する可能性があります。
  • Apache インスタンスに直接アクセスして、問題が解決しないかどうかを確認してください。
    • http://127.0.0.1:8001/admin/
    • ロケーション ヘッダーにポートがない場合:
      • ランダムなポート (たとえば 8005) で Django 開発サーバーを起動し、問題が解決しないかどうかを確認します。
        • 問題が解決しない場合は、コードに問題があります。
        • 問題が解決しない場合は、Apache が異常なことを行っているか、WSGI/Django がポート番号を特定するために必要なすべての情報を取得していません。
          • wsgi スクリプトと django アプリの両方が環境内のポート番号を認識できることを確認してください。
    • ロケーション ヘッダーにポートが含まれている場合:
      • Nginxは何らかの理由でそれを取り除いています。
      • Apache をループから切り離してみてください。おそらく必要ないでしょう。
        • Django を FastCGI サーバーとして起動し、Apache の代わりに Nginx をそれに接続します。
          • これにより、サーバーのオーバーヘッドの一部が実際に削減されます (リクエストの受け渡しの減少、余分なスレッド、メモリの使用など)。
          • こちらのかなり良いセットアップガイド。

忍者編集!
これが役立つかどうかはわかりませんが、リダイレクトでポート番号を無視するためのオプションが Nginx にあるようです。URLが死んでいるのでこちらから貼り付けます

http://wiki.codemongers.com/NginxHttpCoreModule#port_in_redirect

syntax: port_in_redirect [ on|off ]
default: port_in_redirect on
context: http, server, location

ディレクティブは、nginx によって処理されるリダイレクトのポート表示を許可または禁止します。

于 2010-02-01T16:03:35.927 に答える
1

ユージ、ジェームス、

もう一度助けてくれてありがとう!

解決策はここに記載されていることが判明しました:変更proxy_set_headerHost $host;proxy_set_headerHost $host:$server_port;うまくいきました!

于 2010-02-03T16:01:59.693 に答える