ホームページ >バックエンド開発 >PHPチュートリアル >Nginx サーバーで ThinkPHP の pathinfo モードを使用する際の問題
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 チュートリアルに興味のある友人に役立つことを願っています。