nginx環境thinkphp、500エラー

WBOY
WBOYオリジナル
2016-06-23 13:53:122069ブラウズ

今天吧网站放到nginx下centos环境,程序是thinkphp3.2的,首页能正常显示,内链所有都是500错误,贴出配置代码和错误日志,求解决方案!!

server {    listen       80;    server_name  此处网站域名;    root   /usr/local/www/web/go;    location / {    root   /usr/local/www/web/go;    index index.php index.html index.htm;        if (!-e $request_filename) {        rewrite ^(.*)$ /index.php/$1 last;        break;    }            error_page   500 502 503 504  /50x.html;        location = /50x.html {            root   /usr/share/nginx/html;        }        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000        location ~ .php$ {        root   /usr/local/www/web/go;            fastcgi_pass   127.0.0.1:9000;            fastcgi_index  index.php;            #定义变量 $path_info ,用于存放pathinfo信息                set $path_info "";                #定义变量 $real_script_name,用于存放真实地址                set $real_script_name $fastcgi_script_name;                #如果地址与引号内的正则表达式匹配                if ($fastcgi_script_name ~ "^(.+?\.php)(/.+)$") {                        #将文件地址赋值给变量 $real_script_name                        set $real_script_name $1;                        #将文件地址后的参数赋值给变量 $path_info                        set $path_info $2;                }                #配置fastcgi的一些参数                fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;                fastcgi_param SCRIPT_NAME $real_script_name;                fastcgi_param PATH_INFO $path_info;                #fastcgi_param  SCRIPT_FILENAME  /usr/local/www/web/go$fastcgi_script_name;                include        fastcgi_params;        }      }      }


nginx日志:

[root@VM_161_64_centos nginx]# 29068#0: *41 rewrite or internal redirection cycle while processing "/index.php//index.php//index.php//index.php//index.php//index.php//index.php//index.php//index.php//index.php//index.php//index.php/home/user/register.html", client: 这里IP, server: 这里域名, request: "GET /index.php/home:Q


回复讨论(解决方案)

codeigniter在nginx下配置
应该也适用 thinkphp,你对比一下

server {       listen  80;       server_name     www.phpno.com;       root /home/www/www_phpno_com/admin_wwwroot;       access_log off;       error_page 404  /404.html;       location /404.html {               root /home/www/www_phpno_com/admin_wwwroot;       }       location /{               index index.html index.htm index.php;               if (-e $request_filename) {                       break;               }               if (!-e $request_filename) {                       rewrite ^/(.*)$ /index.php/$1 last;                       break;               }       }        location ~ .+\.php($|/) {           root           /home/www/www_phpno_com/admin_wwwroot;           fastcgi_index index.php;           fastcgi_split_path_info ^(.+\.php)(.*)$;           fastcgi_param   SCRIPT_FILENAME $document_root$fastcgi_script_name;           fastcgi_param   PATH_INFO               $fastcgi_path_info;           fastcgi_param   PATH_TRANSLATED $document_root$fastcgi_path_info;           fastcgi_pass   127.0.0.1:9000;       #    fastcgi_index  index.php;       #    fastcgi_param  SCRIPT_FILENAME  /home/www/www_phpno_com/admin_wwwroot/$fastcgi_script_name;       #    fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html/$fastcgi_script_name;           include        fastcgi_params;       }   }

codeigniter在nginx下配置
应该也适用 thinkphp,你对比一下
[code=text]server {
    listen       80;
    server_name 域名;
    root   /usr/local/www/web/go;

    location / {
    index index.php index.html index.htm;
         if (-e $request_filename) {
                       break;
               }
               if (!-e $request_filename) {
                       rewrite ^/(.*)$ /index.php/$1 last;
                       break;
               }
    
        error_page   500 502 503 504  /50x.html;

        location = /50x.html {
            root   /usr/share/nginx/html;
        }
 
       # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        location ~ .php$ {
        root   /usr/local/www/web/go;
            fastcgi_index index.php;
            fastcgi_pass   127.0.0.1:9000;
            
                #配置fastcgi的一些参数
                fastcgi_split_path_info ^(.+\.php)(.*)$;
           fastcgi_param   SCRIPT_FILENAME $document_root$fastcgi_script_name;
           fastcgi_param   PATH_INFO               $fastcgi_path_info;
           fastcgi_param   PATH_TRANSLATED $document_root$fastcgi_path_info;
                include        fastcgi_params;
        }
 
     }
      
}


改成这样了,还是500呢,需要改哪里呀?

1# 正解啊
你的问题就是伪静态问题,改正确了,就OK了

サーバーエラーログを見てください

1. nginx が原因ではないことを確認します。簡単なプログラムでテストできます
2. phpのエラー表示機能をオンにして、エラーメッセージが出力されるか確認してください
3. preg_replace_callbackの上位バージョンには深刻なメモリリーク問題があると言われているので、thinkphp3. 2 使用する必要があります

1. nginx が原因ではないことを確認します。簡単なプログラムでテストできます
2. phpのエラー表示機能をオンにして、エラーメッセージが出力されるか確認してください
3. preg_replace_callbackの上位バージョンには深刻なメモリリーク問題があると言われているので、thinkphp3. 2 使用する必要があります


私 ホームページは表示できますが、右隅のデバッグを開いて内部リンクをクリックすると、ページが表示されなくなります。 500 です

1# 正解です
あなたの問題は疑似静的問題です、それを修正すれば問題ありません


どういう意味ですか?

ランタイム ディレクトリをクリアして再試行してください

500 エラーが発生した場合は、プログラムに問題があることを意味します (もちろん、他にも問題がある可能性がありますが、最初に確認するのはプログラムです)
拒否した場合エラー表示機能をオンにします。どこに問題があるかわかりますか?
占いでも生年月日は必要じゃないですか? R w #rewrite^(.*) $ /Index.php/ $1 last; 404 ==


ランタイム ディレクトリをクリアして再試行してください

500 エラーが発生した場合は、プログラム (のもちろん他にも問題があるかもしれませんが、最初に確認するのはプログラムです)

エラー表示機能をオンにすることを拒否しました。どこに問題があるのか​​をどうやって知ることができますか?

占いでも生年月日は必要じゃないですか?

PHP がインストールされている場所を見つけるのを待ってください ==

phpinfo()

php.ini がどこにあるかわかりませんか?
error_reporting = E_ERROR

display_errors = On
これら 2 つを開いてサービス nginx を再起動します

まだ 404 が出力され、エラーは出力されません、ログを確認する必要がありますか?それともPHPを再起動しますか?


phpinfo()

php.ini がどこにあるかわかりませんか?

[23-Jul-2014 08:33:51] PHP 通知: 未定義 インデックス: SCRIPT_NAME in /usr/local/www/erp/ThinkPHP/ThinkPHP.php on 82
[23-Jul-2014 09:06: 15] PHP 通知: 未定義 インデックス: SCRIPT_NAME in /usr/local/www/erp/ThinkPHP/ThinkPHP.php on line 82
[23-Jul-2014 10:05:53] PHP 通知: 未定義 インデックス: SCRIPT_NAME in /usr /local/www/erp/ThinkPHP/ThinkPHP.php on line 82
[23-Jul-2014 10:09:42] PHP 通知: 未定義 インデックス: SCRIPT_NAME in /usr/local/www/erp/ThinkPHP/ThinkPHP.php 82 行目
[23-Jul-2014 10:22:08] PHP 警告: phpinfo(): システムのタイムゾーン設定に依存するのは安全ではありません。 date.timezone 設定または date_default_timezone_set() 関数を使用することが*必須*です。 これらの方法のいずれかを使用してもこの警告が表示される場合は、タイムゾーン識別子のスペルを間違えている可能性があります。 /usr/local/www/web/dolanne/go/info.php の 2 行目では、「CST/8.0/DST なし」の代わりに「アジア/重慶」を選択しました
[23-Jul-2014 10:28:04] PHP 警告: phpinfo(): システムのタイムゾーン設定に依存するのは安全ではありません。 date.timezone 設定または date_default_timezone_set() 関数を使用することが*必須*です。 これらの方法のいずれかを使用してもこの警告が表示される場合は、タイムゾーン識別子のスペルを間違えている可能性があります。 /usr/local/www/web/dolanne/go/info.php の 2 行目で、代わりに「CST/8.0/DST なし」として「アジア/重慶」を選択しました

PHP 通知: 未定義のインデックス: /usr 内の SCRIPT_NAME /local/www/erp/ThinkPHP/ThinkPHP.php on line 82
$_SERVER['SCRIPT_NAME'] 存在しません、不知道他们是怎么测试的!
在 入口文件开始处
$_SERVER['SCRIPT_NAME'] = $ _SERVER['PHP_SELF'];

PHP 警告: phpinfo(): システムのタイムゾーン設定に依存するのは安全ではありません。 date.timezone 設定または date_default_timezone_set() 関数を使用することが*必須*です。 これらの方法のいずれかを使用してもこの警告が表示される場合は、タイムゾーン識別子のスペルを間違えている可能性があります。 /usr/local/www/web/dolanne/go/info.php の 2 行目では、「CST/8.0/夏時間なし」の代わりに「アジア/重慶」を選択しました
你没有设置時間区、按他的提案设置一下就好了

500 变成 404
不是进步而退步!
404 是找不到目标页,显然是你重写指错了地
500 是被执行的程序出现了问题,而また返還不能戻る误情報。nginx が 500 を発行し、アプリケーションが拒否することを示します

500 が 404 に変わります

これではなく退行です!
404 はターゲットに到達できません、確かに重複書き込みです错了地方
500 是被実行されたプログラムには問題が発生しましたが、拒否メッセージを返すことができません。 4
ではない

404 はターゲットに到達できませんが、
500 が実行されているプログラムは問題を起こしており、またエラー情報を返すことができません。开绝响应

现在回到出版帖的時候状態态了 php日志还是上面那畝,nignx日志就是出版帖0楼的那珂,肿么办

500 は 404 になります
それは進歩ではなく後退です!
404 は、明らかに書き換え時に間違った場所を指定したことを意味します。
500 は、実行されたプログラムに問題があり、エラー メッセージが返されなかったことを意味します。そこで、nginx は 500 エラーを送信し、アプリケーションが応答を拒否したことを示しました


ハハハハ、私が自分でやったのです、、、
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。