Greg Beaver のブログで最近公開された、PHP の文字列と == 演算子を比較する新しい記事では、文字列を PHP の == 演算子と比較する際に注目すべき問題について言及しています。
PHPでは数値データ(数値を含む文字列など)を数値処理に変換する場合がありますが、==演算子もその一つです。 == 演算子を使用して 2 つの文字列を大まかに比較すると、PHP は のような数値文字列を比較用の数値に変換します。次の実験により、この結論が確認されます。 var_dump(<span><span>'01' <br><span>== </span><br>1<span></span>);</span><span></span><span></span>?><span></span><span></span><span><br> </span>上記のコードの出力結果は次のとおりです: <span>ブール(true) <span> そのため、文字列を比較する場合は、 === 演算子を使用して文字列を厳密にチェックするか、起こり得る問題を回避するために strcmp() などの関数を使用することをお勧めします。 PHPマニュアルの「PHP型比較表」でも詳しく説明されています。 <span></span><br> さらに、一般的に使用される in_array() 関数にも弱い型の問題があります。次のコードを参照してください。 </span>, array(</span></span>'1'
)));
?> セキュリティチェックを行う PHP プログラマーは、これがどのようなセキュリティ上の問題を引き起こすかを知っていますよね?幸いなことに、
in_array() 関数には 3 番目のパラメーターが用意されており、これを true に設定すると、次のコードに示すように、in_array() 関数の必須の型チェック メカニズムをオンにすることができます。 ;?php <span>var_dump<span><br>(</span><span>in_array</span><span>(</span><span>'01'</span><span>, array(</span><span>'1'</span><span>), </span><span>true<br></span>)); <span>?& gt;<span> </span><br></span></span>
出力結果は次のとおりです:
bool(false)
PHP は弱い型付け言語であるため、つまり、PHP ではデータ型の概念が弱くなっています。したがって、プログラミング時にデータ型を無視しすぎると (これはほとんどの PHP プログラマーに共通する問題でもあります)、いくつかの問題が発生し、さらにはセキュリティの脆弱性が発生します。最後に、迷惑な格言にあるように、外部データを厳密にチェックしてフィルタリングします。
上記では、== 演算子を使用した文字列比較のための PHP での User-Agent 文字列の使用法を紹介しています。これには、User-Agent 文字列の内容も含まれており、PHP チュートリアルに興味のある友人に役立つことを願っています。