ホームページ >バックエンド開発 >PHPチュートリアル >PHP の filter_input() 関数を使用して、単一ユーザーによって入力されたデータを検証する

PHP の filter_input() 関数を使用して、単一ユーザーによって入力されたデータを検証する

王林
王林オリジナル
2023-11-04 10:12:191541ブラウズ

PHP の filter_input() 関数を使用して、単一ユーザーによって入力されたデータを検証する

PHP の filter_input() 関数を使用して、単一ユーザーが入力したデータを検証する

Web アプリケーションを開発する場合、ユーザーが入力したデータのセキュリティは非常に重要です。悪意のある攻撃や脆弱性を防ぐためには、ユーザーが入力したデータを厳密に検証し、フィルタリングする必要があります。 PHP の filter_input() 関数は、ユーザーが入力したデータを検証およびフィルタリングするためのシンプルかつ強力な方法を提供します。

filter_input() 関数は、スーパーグローバル変数 ($_GET、$_POST、$_COOKIE など) およびその他の変数を検証するために使用できます。指定されたフィルター ルールに従って入力データをフィルターし、フィルターされた値を返します。フィルタリングが失敗した場合は FALSE を返します。一般的なフィルター ルールの例をいくつか示します。

  1. 整数の検証: FILTER_VALIDATE_INT
  2. 電子メール アドレスの検証: FILTER_VALIDATE_EMAIL
  3. URL の検証: FILTER_VALIDATE_URL
  4. 特殊フィルター文字: FILTER_SANITIZE_SPECIAL_CHARS

これは、filter_input() 関数を使用してユーザーが入力した電子メール アドレスを検証する方法を示す例です:

$email = filter_input(INPUT_POST, 'email', FILTER_VALIDATE_EMAIL);
if ($email) {
    echo "输入的电子邮件地址是有效的:$email";
} else {
    echo "输入的电子邮件地址无效";
}

上の例では、 filter_input() 関数は、ユーザーが POST メソッドを通じて送信した「email」という名前の入力を検証するために使用されます。フィルター ルール FILTER_VALIDATE_EMAIL を使用して、入力された電子メール アドレスが有効であることを確認しました。検証が成功した場合は有効なメールアドレスが出力され、そうでない場合は「入力されたメールアドレスが無効です」と出力されます。

単一の入力の検証に加えて、filter_input_array() 関数を使用して入力データのセットを検証することもできます。 filter_input_array() 関数は、検証する変数とそれに対応するフィルター ルールを指定するパラメーターとして連想配列を受け入れることができます。以下は、filter_input_array() 関数を使用して入力データのセットを検証する方法を示す例です。

$filters = array(
    'name' => FILTER_SANITIZE_STRING,
    'age'  => array(
        'filter'  => FILTER_VALIDATE_INT,
        'options' => array(
            'min_range' => 1,
            'max_range' => 100
        )
    ),
    'email' => FILTER_VALIDATE_EMAIL
);

$input = filter_input_array(INPUT_POST, $filters);

if ($input !== NULL && $input !== FALSE) {
    echo "验证通过";
} else {
    echo "输入数据有误";
}

上の例では、連想配列 $filters を使用して検証する変数を指定し、対応するフィルター ルール。 「name」という名前の変数に有効な文字列が含まれていることを確認し、「age」という名前の変数が 1 ~ 100 の整数であることを確認し、「email」という名前の変数が有効な電子メール アドレスであることを確認しました。次に、filter_input_array() 関数を使用して、POST メソッド経由で送信された入力データのセットを検証し、返された結果を変数 $input に割り当てます。検証に合格した場合は「検証に合格しました」が出力され、そうでない場合は「入力データが正しくありません」が出力されます。

入力検証に filter_input() 関数または filter_input_array() 関数を使用すると、潜在的なセキュリティ リスクや脆弱性攻撃から Web アプリケーションを効果的に保護できます。これらの関数はある程度のセキュリティを提供しますが、準備されたステートメントの使用やファイルのアップロードの検証など、他のセキュリティ対策と組み合わせてアプリケーション全体のセキュリティを向上させることをお勧めします。

以上がPHP の filter_input() 関数を使用して、単一ユーザーによって入力されたデータを検証するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。