web-dev-qa-db-ja.com

PHPメール検証

[〜#〜] php [〜#〜]の場合、pregを使用した最良の電子メール検証は何ですか[〜#〜] not [〜#〜]ereg非推奨/削除であるため。

私はしない Webサイトが存在するかどうかを確認する必要があります(最大のセキュリティとは異なります)。

eregを使用して多くの方法を見つけましたが、(明らかに)良い方法ではありません。

28
Mark Lalor

FILTER_VALIDATE_EMAILフィルターを使用することをお勧めします。

if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
    //valid
}

その正規表現 を直接使用することもできます。

"/^(?!(?:(?:\\x22?\\x5C[\\x00-\\x7E]\\x22?)|(?:\\x22?[^\\x5C\\x22]\\x22?)){255,})(?!(?:(?:\\x22?\\x5C[\\x00-\\x7E]\\x22?)|(?:\\x22?[^\\x5C\\x22]\\x22?)){65,}@)(?:(?:[\\x21\\x23-\\x27\\x2A\\x2B\\x2D\\x2F-\\x39\\x3D\\x3F\\x5E-\\x7E]+)|(?:\\x22(?:[\\x01-\\x08\\x0B\\x0C\\x0E-\\x1F\\x21\\x23-\\x5B\\x5D-\\x7F]|(?:\\x5C[\\x00-\\x7F]))*\\x22))(?:\\.(?:(?:[\\x21\\x23-\\x27\\x2A\\x2B\\x2D\\x2F-\\x39\\x3D\\x3F\\x5E-\\x7E]+)|(?:\\x22(?:[\\x01-\\x08\\x0B\\x0C\\x0E-\\x1F\\x21\\x23-\\x5B\\x5D-\\x7F]|(?:\\x5C[\\x00-\\x7F]))*\\x22)))*@(?:(?:(?!.*[^.]{64,})(?:(?:(?:xn--)?[a-z0-9]+(?:-[a-z0-9]+)*\\.){1,126}){1,}(?:(?:[a-z][a-z0-9]*)|(?:(?:xn--)[a-z0-9]+))(?:-[a-z0-9]+)*)|(?:\\[(?:(?:IPv6:(?:(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){7})|(?:(?!(?:.*[a-f0-9][:\\]]){7,})(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,5})?::(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,5})?)))|(?:(?:IPv6:(?:(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){5}:)|(?:(?!(?:.*[a-f0-9]:){5,})(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,3})?::(?:[a-f0-9]{1,4}(?::[a-f0-9]{1,4}){0,3}:)?)))?(?:(?:25[0-5])|(?:2[0-4][0-9])|(?:1[0-9]{2})|(?:[1-9]?[0-9]))(?:\\.(?:(?:25[0-5])|(?:2[0-4][0-9])|(?:1[0-9]{2})|(?:[1-9]?[0-9]))){3}))\\]))$/iD"

ただしその場合、正規表現にバグが見つかった場合は、PHPを更新するだけでなく、プログラムを更新する必要があります。

78
Artefacto

非常に長い正規表現 を使用したくない場合を除き、カバーされていない有効な電子メールアドレスに遭遇します(Unicodeと考えてください)。また、偽のメールアドレスは有効として渡されるので、単に[email protected]と書いてそれを回避できるのであれば、検証のポイントは何ですか?

メールアドレスを検証する最良の方法は、クリックするリンクを含む確認メールを送信することです。これは、メールアドレスが有効な場合にのみ機能します。簡単で、正規表現を使用する必要はありません。

3
nico
function check_email($check) {
$expression = "/^[a-zA-Z0-9._-]+@[a-zA-Z0-9._-]+\.([a-zA-Z]{2,4})$/";
if (preg_match($expression, $check)) {
    return true;
} else {
    return false;
} 
}

以下の例のようにif()条件で呼び出します:

if(!check_email($_REQUEST['ContactEmail'])){
  $register_error ="Enter the correct email address!<br />";
  $reg_error=1; 
}
0
Gaurav Gupta