はじめに
問題を見つけたので、今日それを共有します。プロセス全体を説明しましょう。
質問: 会社には、smarty に基づいて書かれたフレームワークがあります。私は PHP のアップグレードを担当しています。メンテナンス スタッフが新しい環境をデプロイした後、テスターが私のところに来て、頻繁にエラー (エラー: ファイルが見つかりません) を報告しました。
コードを追跡したところ、smartyによって報告されたエラーであることが判明しました。
エラー: ここで報告されたファイルは存在しません。
思考プロセス:
1. 当初はプログラム内にファイルが存在しないと思っていたのですが、実際にはファイルが存在していたことが分かりました。
2. その後、PHP カーネルに問題があるのではないかと考え、関連する PHP カーネル ファイルを調べましたが、問題はありませんでした。その結果、私はプロジェクトマネージャーにすべてのプロセスを話しました。 ——問題は解決していないので、このままにしておきます。現時点ではアップグレードが遅れています。
今日もこの問題を発見しました。最初は PHP のバージョンがアップグレードされたのかと思いましたが、アップグレードされていないことがわかりました。 ——その後、ディレクトリ全体を 777 に設定しましたが、すべて問題ありませんでした (chmod 777 -R ディレクトリ)。 file_exists()メソッドの問題なのでしょうか。
そこで、関連するデバッグと実験を行いました。
デバッグプロセスのデバッグコード:
ディレクトリ:
各権限を確認してください。test には www に対する権限がありませんが、実行ファイル Index.php には読み取りおよび書き込みの実行権限があり、含まれているファイル test.txt には読み取りおよび書き込みの権限があります。
実行結果:
ディレクトリの実行権限はfile_exists()に影響します
1. テストに最大の許可を与える - 755
成功したということは、file_exists()関数がディレクトリ権限によって制限されていることを意味します。
それでは、どのような種類のディレクトリ権限が file_exists() に影響を与えるのでしょうか?
いくつか実験してみました:
1. ファイルの上位ディレクトリに書き込み権限しかない場合、ファイルは存在しません。
2. ファイルの親ディレクトリは、読み取り権限しかない場合でもファイルが存在しないと報告します。3. すべての上位ディレクトリに実行権限がある場合、報告されたファイルは存在し、すべてが正常です。
結果は、 file_exists() がファイルの存在を判定する際に、各ディレクトリに実行権限があるかどうかを再帰的に判定していることがわかります。
ファイルパスを相対パスに変更しても、同じ結果が得られます。
概要
file_exists がディレクトリの実行権限の影響を受けることは PHP マニュアルには記載されていません。今日は、この記事を通じて、同様にこの問題を抱えている開発者に情報を伝えたいと思います。これは警告として受け取ってください。
追加情報
皆さん、コメントをありがとうございます、とても役に立ちます。皆さんのご意見を参考に再度マニュアルを確認してみたところ、確かにディレクトリに実行権限がないとphp-fpmアプリケーションプロセスはこのディレクトリ内にファイルを検索することはできません(実際にはファイルが存在しないものとみなされます)。実行可能ディレクトリが存在しないものとみなされます)。実行権限を中心にマニュアルの内容を合わせて検討していただけます。ここでは、読み取りおよび書き込み権限について詳しくは説明しません (一般に、これらは簡単に理解できます)。
明らかにマニュアルには、ディレクトリの実行権限について明確な指示があります。ディレクトリに対する実行権限とは、検索される権限を持っていることを意味します。
この記事が役に立った場合、またはこの種の問題の解決に役立つ場合は、執筆のモチベーションを高めるためにお勧めしてください。