ホームページ >バックエンド開発 >PHPチュートリアル >Nginx サーバーで ThinkPHP の pathinfo モードを使用する際の問題

Nginx サーバーで ThinkPHP の pathinfo モードを使用する際の問題

WBOY
WBOYオリジナル
2016-08-08 09:25:121201ブラウズ

LNMP ワンクリックインストールパッケージをインストールした後、thinkphp の pathinfo モードが使用できないことがわかりました。
Baidu を少し調べたところ、nginx/conf/vhost/domain 名ファイルに pathinfo を開く手順があることがわかり、pathinfo を起動しました。
しかし、プロジェクトはまだ実行できなかったので、コードをローカルとサーバーで同時に実行しました。

<code><span><span><?php</span>
var_dump(<span>$_SERVER</span>);</span></code>

PHP_SELF に違いがあることがわかりました。問題はここにあるかもしれません。
次に、プロジェクト内で PHP_SELF を検索し、次のファイルを見つけます:
ThinkPHP.php

<code><span>if</span>(<span>IS_CGI</span>) {
            <span>//</span><span>CGI</span>/<span>FASTCGI</span>模式下
            <span>$_temp</span>  = explode(<span>'.php'</span>,<span>$_SERVER</span>[<span>'PHP_SELF'</span>]);
            define(<span>'_PHP_FILE_'</span>,   rtrim(str_replace(<span>$_SERVER</span>[<span>'HTTP_HOST'</span>],<span>''</span>,<span>$_temp</span>[<span>0</span>].<span>'.php'</span>),<span>'/'</span>));
        }<span>else</span> {
            define(<span>'_PHP_FILE_'</span>,    rtrim(<span>$_SERVER</span>[<span>'SCRIPT_NAME'</span>],<span>'/'</span>));
        }</code>

つまり、ThinkPHP は CGI モードで PHP_SELF に依存しています
問題はまさにここにあります。 最後に、Baidu で検索したところ、脆弱性をブロックするために php.ini に設定されていることが判明しました:

<code><span>cgi.fix_pathinfo</span>=<span>0</span></code>

この設定行のせいで、PHP_SELF の値が逸脱しています。

ただし、LNMP 統合パッケージの pathinfo.conf は

<code>try_files <span>$fastcgi_script_name</span> =<span>404</span></code>

を使用してこの脆弱性を解決しているため、php.ini を

<code><span>cgi.fix_pathinfo</span>=<span>1</span></code>

に変更できます。サーバーを再起動します。OK、問題は解決しました

上記では、Nginx サーバーで ThinkPHP の pathinfo モードを使用する場合の問題を、関連する内容も含めて紹介しています。PHP チュートリアルに興味のある友人に役立つことを願っています。

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