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

WBOY
リリース: 2016-08-08 09:25:12
オリジナル
1138 人が閲覧しました

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 チュートリアルに興味のある友人に役立つことを願っています。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!