@R_301_461@校验邮箱地址的方法很多, 比较常用的就是自己写正则了, 不过正则多麻烦, 我@R_301_461@自带了方法做校验。
filter_var
filter_var是@R_301_461@内置的一个变量过滤的方法, 提供了很多实用的过滤器, 可以用来校验整数、浮点数、邮箱、URL、MAC地址等。
具体的过滤器参考: filters.validate
filter_var如果返回false,说明变量无法通过过滤器, 也就是不合法了。
var_dump(filter_var($email,FILTER_VALIDATE_EMAIL));
$email = "asb";
var_dump(filter_var($email,FILTER_VALIDATE_EMAIL));
$email = "1@a.com";
var_dump(filter_var($email,FILTER_VALIDATE_EMAIL));
输出:
string(21) "lastchiliarch@163.com"
bool(false)
string(7) "1@a.com"
对于asb这种非法邮箱格式返回了false,但对于则通过了,还是略有瑕疵啊。
不过一般的正则也通过会认为是一个合法的邮箱, 那有啥办法可以更精准的验证呢?
checkdnsrr
checkdnsrr其实是用来查询指定的主机的DNS记录的,我们可以借用它来验证邮箱是否存在。
输出:
bool(true)
bool(false)
可以看到, 很完美, 唯一的缺点就是太慢了, 毕竟是要做一次网络请求。 所以不适合同步对大量的邮箱采用这种做法去校验。
filter_var+checkdnsrr
我们可以接合filter_var 和checkdnsrr做校验, 对于绝大多数的非法邮箱肯定会在filter_var的时候就挂掉了, 剩下的再用
checkdnsrr进一步判断。
if(checkdnsrr(array_pop(explode("@","MX") === false) {
echo "invalid email: $email \n";
continue;
}
}
输出: invalid email: 1@a.com
但要注意的是, 由于只是检查MX记录, 所以只能判断163.com是存在的, 但不能说明lastchiliarch这个用户是存在的。
想要更精确的判断邮箱存在, 那只能连接到smtp服务器去验证了。
下面为大家分享的@R_301_461@邮箱地址正则表达式验证,具体内容如下
\n"; $user_name = preg_replace( $pattern,"$1",$email_address ); $domain_name = preg_replace( $pattern,"$2",$email_address ); $reply .= "用户名:".$user_name."
\n"; $reply .= "域名:".$domain_name."
\n\n"; } else { $reply = "您输入的电子邮件地址不合法"; } } ?>