検証

例1 filter_var() でのメールアドレスの検証

<?php
$email_a 
'joe@example.com';
$email_b 'bogus';

if (
filter_var($email_aFILTER_VALIDATE_EMAIL)) {
    echo 
"($email_a) はメールアドレスとして有効です。\n";
}
if (
filter_var($email_bFILTER_VALIDATE_EMAIL)) {
    echo 
"($email_b) はメールアドレスとして有効です。\n";
} else {
    echo 
"($email_b) はメールアドレスとして無効です。\n";
}
?>

上の例の出力は以下となります。

(joe@example.com) はメールアドレスとして有効です。
(bogus) はメールアドレスとして無効です。

例2 filter_var() での IP アドレスの検証

<?php
$ip_a 
'127.0.0.1';
$ip_b '42.42';

if (
filter_var($ip_aFILTER_VALIDATE_IP)) {
    echo 
"(ip_a) は IP アドレスとして有効です。";
}
if (
filter_var($ip_bFILTER_VALIDATE_IP)) {
    echo 
"(ip_b) は IP アドレスとして有効です。";
}
?>

上の例の出力は以下となります。

(ip_a) は IP アドレスとして有効です。

例3 filter_var() でのオプションの指定

<?php
$int_a 
'1';
$int_b '-1';
$int_c '4';
$options = array(
    
'options' => array(
                      
'min_range' => 0,
                      
'max_range' => 3,
                      )
);
if (
filter_var($int_aFILTER_VALIDATE_INT$options) !== FALSE) {
    echo 
"整数値 (int_a) は有効な値 (0 から 3 までの間) です。\n";
}
if (
filter_var($int_bFILTER_VALIDATE_INT$options) !== FALSE) {
    echo 
"整数値 (int_b) は有効な値 (0 から 3 までの間) です。\n";
}
if (
filter_var($int_cFILTER_VALIDATE_INT$options) !== FALSE) {
    echo 
"整数値 (int_c) は有効な値 (0 から 3 までの間) です。\n";
}

$options['options']['default'] = 1;
if ((
$int_c filter_var($int_cFILTER_VALIDATE_INT$options)) !== FALSE) {
    echo 
"整数値 (int_c) は有効な値 (0 から 3 までの間) で、その値は $int_c です。";
}
?>

上の例の出力は以下となります。

整数値 (int_a) は有効な値 (0 から 3 までの間) です。
整数値 (int_c) は有効な値 (0 から 3 までの間) で、その値は 1 です。

add a note add a note

User Contributed Notes 4 notes

up
3
Anonymous
1 year ago
the problem listed before with the e-mail address: gnix@lineone.netsteve.gynes@lane4.co.uk being flagged as valid seems to not be a problem anymore, at least not on 5.6.30
up
1
dows
1 year ago
It considers umlauts-domains as invalid.

test@täst.de -> false
täst@test.de -> false
up
-105
Stan
5 years ago
HP 5.3.3 and 5.2.14 had a bug (http://bugs.php.net/52929) related to FILTER_VALIDATE_EMAIL, which resulted in segfault when validating large values. Simple and safe workaround for this is using strlen() before filter_val(). I'm not sure about 5.3.4 final, but it is written that some 5.3.4-snapshot versions also were affected.

Originally posted here - http://stackoverflow.com/questions/5855811/how-to-validate-an-email-in-php#comment6729146_5855853.
up
-122
ghazouanijs at gmail dot com
4 years ago
invalid email skip this filter
example : gnix@lineone.netsteve.gynes@lane4.co.uk
To Top