[〜#〜] php [〜#〜]の場合、pregを使用した最良の電子メール検証は何ですか[〜#〜] not [〜#〜]ereg非推奨/削除であるため。
私はしない Webサイトが存在するかどうかを確認する必要があります(最大のセキュリティとは異なります)。
eregを使用して多くの方法を見つけましたが、(明らかに)良い方法ではありません。
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を更新するだけでなく、プログラムを更新する必要があります。
非常に長い正規表現 を使用したくない場合を除き、カバーされていない有効な電子メールアドレスに遭遇します(Unicodeと考えてください)。また、偽のメールアドレスは有効として渡されるので、単に[email protected]と書いてそれを回避できるのであれば、検証のポイントは何ですか?
メールアドレスを検証する最良の方法は、クリックするリンクを含む確認メールを送信することです。これは、メールアドレスが有効な場合にのみ機能します。簡単で、正規表現を使用する必要はありません。
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;
}