PHPフィルター(1)
PHP フィルターには 2 つのタイプが含まれます
検証: 検証項目が合法かどうかを検証するために使用されます
サニタイズ: 検証された項目をフォーマットするために使用され、検証項目の値を変更したり、不正な文字を削除したりする可能性があります。
input_filters_list() 関数は、現在のシステムでサポートされているすべてのフィルターをリストするために使用されます。
1 <table>2 <tr><td>Filter Name</td><td>Filter ID</td></tr>3 <?php4 foreach(filter_list() as $id =>$filter)5 {6 echo '<tr><td>'.$filter.'</td><td>'.filter_id($filter).'</td></tr>'."\n";7 }8 ?>9 </table>
上記のコードは次の情報を出力します
フィルター名フィルターID
int 257
boolean 258
float 259
validate_regexp 272
validate_url 273
validate_email 274
validate_ip 275
文字列 513
ストリップ 513
エンコード 514
special_chars 515
unsafe_raw 516
email 517
url 518
number_int 519
number_float 520
magic_quotes 521
callback 1024
各フィルターには一意の ID があります。ここでの各フィルターは、filter_var() 関数で使用できます。以下にその使い方を一つずつ紹介していきます。上記の文字列と StrippedID が同じであることに注意してください。これは、これらが同じフィルターであるか、同じフィルターの単なる 2 つのエイリアスであるためです。
データをフィルタリングする
filter_var() メソッドを使用してデータをフィルタリングします。 以下は簡単なフィルタリングの例です。今回は、$int 変数の内容を変更します
1 <?php2 3 /*** an integer to check ***/4 $int = 1234;5 /*** validate the integer ***/6 echo filter_var($int, FILTER_VALIDATE_INT);7 //12348 ?>
このときコードを実行すると、変数の出力がないことが分かりました。これは、$in 変数が検証を通過していないためです。ブール値 (偽) を返します。同時に、$int='' の場合でも bool(false) が返されることに注意してください
整数検証
上記のいくつかのコードは、指定された値が整数であるかどうかを単純に検証します。実際、FILTER_VALIDATE_INT は数値範囲の検証も提供します。変数を検証し、それが整数であるかどうかを判断し、その値が 50 から 100 の間であるかどうかを検証してみましょう
1 <?php2 3 /*** an integer to check ***/4 $int = 'abc1234';5 /*** validate the integer ***/6 echo filter_var($int, FILTER_VALIDATE_INT);7 8 ?>
上記のコードを実行して、42 を見つけてください。と出力されましたが、エラーは見つかりませんでした。これはなぜでしょうか?検証に追加の検証ルールを追加したい場合は、次のように 'options' キーを含む配列を渡す必要があることがわかりました。
1 <?php 2 /*** an integer to check ***/ 3 $int = 42; 4 /*** lower limit of the int ***/ 5 $min = 50; 6 /*** upper limit of the int ***/ 7 $max = 100; 8 9 /*** validate the integer ***/10 echo filter_var($int, FILTER_VALIDATE_INT, array("min_range"=>$min, "max_range"=>$max));11 //4212 ?>
上記のコードを実行すると、ページには何も含まれません。上記は false を返し、検証が成功したことを示しているため、出力されます。このメソッドは、負の数値の範囲検証を実行するために使用することもできます。このメソッドは、単一の範囲値もサポートしています。つまり、
1 <?php 2 /*** an integer to check ***/ 3 $int = 42; 4 /*** lower limit of the int ***/ 5 $min = 50; 6 /*** upper limit of the int ***/ 7 $max = 100; 8 9 /*** validate the integer ***/10 echo filter_var($int, FILTER_VALIDATE_INT, array("options" => array("min_range"=>$min, "max_range"=>$max)));11 12 ?>
などの最大値または最小値の範囲を指定するだけです。 $int が $min より大きい (等しい整数型の値を除く) 場合、コードを実行し、12 を出力します
上記の例は単に単一の値を検証しているだけですが、変数のセットが検証された場合はどうなるでしょうか?答えは、filter_var_array() を使用することです。複数の異なる種類のデータを同時に検証できる機能です。これは簡単な例です
<?php/*** an integer to check ***/$int = 12;/*** lower limit of the int ***/$min = 10;/*** validate the integer ***/echo filter_var($int, FILTER_VALIDATE_INT,array('options'=>array('min_range'=>$min)));//12?>
上記のコードを実行すると、出力は次のようになります
1 -- 109
2 --3 -- -1234
4 --5 --
6 -- 配列
FILTER_VALIDATE_INT フィルターは、8 進数と 16 進数の両方をサポートします。これらの 2 つのフラグは、
FILTER_FLAG_ALLOW_HEX
FILTER_FLAG_ALLOW_OCTAL
フラグを渡すには配列を使用します
1 <?php 2 3 /*** an array of values to filter ***/ 4 $arr = array(10,"109","", "-1234", "some text", "asdf234asdfgs", array()); 5 6 /*** create an array of filtered values ***/ 7 $filtered_array = filter_var_array($arr, FILTER_VALIDATE_INT); 8 9 /*** print out the results ***/10 foreach($filtered_array as $key=>$value)11 {12 echo $key.' -- '.$value.'<br />';13 }14 ?>
PHP Technology Exchange Group 1708557 91

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

phpstormでCLIモードをデバッグする方法は? PHPStormで開発するときは、PHPをコマンドラインインターフェイス(CLI)モードでデバッグする必要がある場合があります。

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。
