原文来自 Laravist 社区: https://www.codecasts.com/blo...正则表达式
一个邮件地址是否有效关系必定程度上决定了这个用户是不是优质用户,或者说成为优质用户的潜质更大。因此在用户注册的时候,咱们一般会绞尽脑汁来验证一个邮箱地址的有限性。json
本文并非简单地讨论使用正则表达式来验证一个邮箱地址是否正确,而是但愿经过更多的手段来真正验证一个邮箱地址的邮箱性
。curl
本文验证一个邮件地址有效性的内容包含如下几个内容:ide
最常规的正则表达式的匹配post
邮件的 DNS 有效性ui
检验 MX 记录的有效性this
屏蔽一次性邮件服务商url
更多细节,好比发起发信请求code
啊哈,在这里推荐你们能够使用 https://www.validator.pizza 邮件验证服务,免费,准确率还很高。具体的实现方式是经过向 validator.pizza 发起 HTTP 请求,用来验证用户邮箱地址是否有效,好比,普通的 PHP 代码能够是这个样子:blog
$email = "666@qq.com"; // 这是一个 laravist 社区注册的垃圾邮件 $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, 'https://www.validator.pizza/email/' . $email); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); $response = curl_exec($ch); curl_close($ch); var_dump($response);
或者在 Laravel 的项目当中,咱们还能够直接扩展 Validator 来实现邮件地址有效性的验证,在 AppServiceProvider
的 boot()
方法添加下面的代码:
public function boot() { Validator::extend('isValid', function ($attribute, $value, $parameters, $validator) { $request = (new Client())->get('https://www.validator.pizza/email/' . $value); $body = json_decode($request->getBody()->getContents()); switch ( $body ) { case $body->status == 400: return false; case !$body->mx: return false; case $body->disposable: return false; default: return true; } }, '邮箱地址不可用'); }
而后在验证的时候能够这样使用:
$this->validate(request(),['email'=>'required|isValid'])
这样一来,基本上就能够应付 90% 以上的邮件地址验证,包含一次性邮件地址验证
和有效性验证
。