PHP の弱い型の安全性の問題

高洛峰
リリース: 2016-10-09 13:29:16
オリジナル
1138 人が閲覧しました

PHPの弱い型の安全性に関する注意事項

1. 型変換の問題

intval();

 

    var_dump(intval('1asdfasd'));  //1

    var_dump(intval('awqw12'));  //0

    var_dump(intval(array()));    //0

    var_dump(intval(array('foo','val'))); //1

    var_dump(intval(0x1A)); //26  十六进制转换

    var_dump(intval('asdfqwer')); //0
ログイン後にコピー

intval 値が文字列に変換された場合はエラーは返されませんが、値が配列に変換された場合は0が返されます。値を変換する 空の配列の場合は 0 を返し、それ以外の場合は 1 を返します

注: PHP は 32 ビットのメモリを使用して、32 ビットの整数を表すことができます。が署名されている場合、-2147483647 ~ 2147483648;です

2. 組み込み関数の緩さの問題

switch();
 
 
 
    $i='3adcd';
 
    switch($i){
 
             case 1:
 
                    echo 'i is 1';
 
                    break;
 
             case 2:
 
                    echo 'i is 2';
 
                    break;
 
             case 3:
 
                    echo 'i is 3';
 
                    break;
 
             default:
 
                   echo 'i is default';
 
                   break;
 
    }
ログイン後にコピー

上記の結果は switch case 3 に入ります。 switch が数値型の case 判定である場合、これはなぜですか? switch はパラメータを int クラスに変換するので、上記を実行すると、まず $i が型変換され、変換結果は 3 になります。 。 。

in_array();

    $arr = [0,1,2,3,'test'];

    var_dump(in_array('abd',$arr));    // true

    var_dump(in_array('1bc',$arr));    // true
ログイン後にコピー

なぜ上記の実行結果はこのようになるのでしょうか? マニュアルを調べたところ、公式の声明によると、in_array はデフォルトで値が等しいかどうかのみを比較し、型が等しいかどうかは比較しません。値は同じなので、上記のようになります。この結果に対して、in_array 関数の 3 番目のパラメーターを True に設定することが、厳密な比較方法になります。

以上は、日々の開発において注意すべき点です。


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート