私は電子メールアドレスを検証するためにこの機能を持っています:
function validateEMAIL($EMAIL) {
$v = "/[a-zA-Z0-9_-.+][email protected][a-zA-Z0-9-]+.[a-zA-Z]+/";
return (bool)preg_match($v, $EMAIL);
}
メールアドレスが有効かどうか確認しても大丈夫ですか?
電子メールアドレスが整形式であるかどうかを確認する最も簡単で安全な方法は、次のfilter_var()
関数を使用することです。
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
// invalid emailaddress
}
さらに、ドメインがMX
レコードを定義しているかどうかを確認できます。
if (!checkdnsrr($domain, 'MX')) {
// domain is not valid
}
しかし、これはまだメールが存在することを保証するものではありません。それを見つける唯一の方法は、確認メールを送信することです。
簡単な回答が得られたので、学習したい場合、または高速回答を使用して先に進む場合は、電子メールアドレスの検証についてお気軽に読んでください。何恨みっこない。
正規表現を使用して電子メールアドレスを検証しようとすることは、「不可能な」タスクです。あなたが作った正規表現は役に立たないと言っても過言ではありません。電子メールアドレスと間違った電子メールアドレスをキャッチするための正規表現の記述に関して3つのRFCがあり、同時に誤検知がないことは、人間にはできないことです。PHPの関数で使用される正規表現のテスト(失敗と成功の両方)については、このリストを確認してくださいfilter_var()
。
組み込みのPHP関数でさえ、電子メールクライアントまたはサーバーはそれを正しく理解していません。それでもほとんどの場合filter_var
、最良の選択肢です。
PHPが(現在)電子メールアドレスの検証に使用している正規表現パターンを知りたい場合は、PHPソースを参照してください。
電子メールアドレスについて詳しく知りたい場合は、仕様を読み始めることをお勧めしますが、一気に読むのは簡単ではないことを警告する必要があります。
filter_var()
すでに述べたように、PHP5.2の時点でのみ利用可能であることに注意してください。以前のバージョンのPHPで動作させたい場合は、PHPで使用されている正規表現を使用できます。
<?php
$pattern = '/^(?!(?:(?:\\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';
$emailaddress = '[email protected]';
if (preg_match($pattern, $emailaddress) === 1) {
// emailaddress is valid
}
PS上記で使用された正規表現パターンに関する注記(PHPソースから)。MichaelRushtonの著作権があるようです。述べられているように:「このコードを自由に使用して再配布してください。ただし、この著作権表示を保持してください。」
これにはfilter_varを使用できます。
<?php
function validateEmail($email) {
return filter_var($email, FILTER_VALIDATE_EMAIL);
}
?>
私の経験では、regex
ソリューションには誤検知が多すぎ、filter_var()
ソリューションには誤検知があります(特にすべての新しいTLDの場合)。
代わりに、アドレスに電子メールアドレスの必要な部分(ユーザー、「@」記号、ドメイン)がすべて含まれていることを確認してから、ドメイン自体が存在することを確認することをお勧めします。
電子メールユーザーが外部ドメインに存在するかどうかを(サーバー側で)判断する方法はありません。
これは、Utilityクラスで作成したメソッドです。
public static function validateEmail($email)
{
// SET INITIAL RETURN VARIABLES
$emailIsValid = FALSE;
// MAKE SURE AN EMPTY STRING WASN'T PASSED
if (!empty($email))
{
// GET EMAIL PARTS
$domain = ltrim(stristr($email, '@'), '@') . '.';
$user = stristr($email, '@', TRUE);
// VALIDATE EMAIL ADDRESS
if
(
!empty($user) &&
!empty($domain) &&
checkdnsrr($domain)
)
{$emailIsValid = TRUE;}
}
// RETURN RESULT
return $emailIsValid;
}
これにより、電子メールが検証されるだけでなく、予期しない文字がないかサニタイズされます。
$email = $_POST['email'];
$emailB = filter_var($email, FILTER_SANITIZE_EMAIL);
if (filter_var($emailB, FILTER_VALIDATE_EMAIL) === false ||
$emailB != $email
) {
echo "This email adress isn't valid!";
exit(0);
}
メールの確認に関する「トップの質問」でこれに回答しました https://stackoverflow.com/a/41129750/1848217
私にとって、メールをチェックする正しい方法は次のとおりです。
- 記号@が存在すること、およびその前後にいくつかの非@記号があることを確認してください。
/^[^@][email protected][^@]+$/
- このアドレスに「アクティベーションコード」を記載したメールを送信してみてください。
- ユーザーが自分のメールアドレスを「アクティブ化」すると、すべてが正しいことがわかります。
もちろん、ユーザーが「奇妙な」メールを入力したときにフロントエンドに警告やツールチップを表示して、ドメイン部分にドットがない、引用符なしで名前にスペースがないなど、よくある間違いを避けることができます。ただし、ユーザーが本当に必要な場合は、アドレス「hello @world」を受け入れる必要があります。
また、電子メールアドレスの標準は縮閉線であり、縮閉線である可能性があることを覚えておく必要があります。そのため、「標準で有効な」正規表現を一度だけ入力することはできません。また、一部の具体的なインターネットサーバーは、共通の標準の詳細に失敗し、実際には独自の「変更された標準」で動作する可能性があることを覚えておく必要があります。
したがって、@をチェックし、フロントエンドでユーザーにヒントを与え、指定されたアドレスに確認メールを送信するだけです。
メールアドレスから提供されたドメインが有効かどうかを確認したい場合は、次のようなものを使用してください。
/*
* Check for valid MX record for given email domain
*/
if(!function_exists('check_email_domain')){
function check_email_domain($email) {
//Get host name from email and check if it is valid
$email_host = explode("@", $email);
//Add a dot to the end of the host name to make a fully qualified domain name and get last array element because an escaped @ is allowed in the local part (RFC 5322)
$host = end($email_host) . ".";
//Convert to ascii (http://us.php.net/manual/en/function.idn-to-ascii.php)
return checkdnsrr(idn_to_ascii($host), "MX"); //(bool)
}
}
有効な電子メール形式は有効な電子メールを意味しないため、これは、標準の電子メール検証とともに、多くの無効な電子メールアドレスをフィルタリングするための便利な方法です。
idn_to_ascii()
(または彼の姉妹関数idn_to_utf8()
)関数はPHPインストールで使用できない場合があることに注意してください。これには、拡張機能PECL intl> = 1.0.2およびPECLidn> = 0.1が必要です。
また、電子メールのドメイン部分としてのIPv4またはIPv6(たとえば[email protected][IPv6:2001:db8::1]
)は検証できず、名前付きホストのみが検証できることに注意してください。
ここで答えを読んだ後、これは私が最終的に得たものです:
public static function isValidEmail(string $email) : bool
{
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
return false;
}
//Get host name from email and check if it is valid
$email_host = array_slice(explode("@", $email), -1)[0];
// Check if valid IP (v4 or v6). If it is we can't do a DNS lookup
if (!filter_var($email_host,FILTER_VALIDATE_IP, [
'flags' => FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE,
])) {
//Add a dot to the end of the host name to make a fully qualified domain name
// and get last array element because an escaped @ is allowed in the local part (RFC 5322)
// Then convert to ascii (http://us.php.net/manual/en/function.idn-to-ascii.php)
$email_host = idn_to_ascii($email_host.'.');
//Check for MX pointers in DNS (if there are no MX pointers the domain cannot receive emails)
if (!checkdnsrr($email_host, "MX")) {
return false;
}
}
return true;
}
さまざまなドット、アンダースコア、ダッシュを使用できる実際の正規表現を探している場合は、次のようになります[a-zA-z0-9.-]+\@[a-zA-z0-9.-]+.[a-zA-Z]+
。これにより、かなりばかげた外観の電子メール[email protected]_matrix.com
を検証できるようになります。
/(?![[:alnum:]]|@|-|_|\.)./
現在、HTML5フォームを使用する場合type=email
、ブラウザーエンジンには独自のバリデーターがあるため、すでに80%安全です。それを補完するには、この正規表現をに追加してpreg_match_all()
無効にします。
if (!preg_match_all("/(?![[:alnum:]]|@|-|_|\.)./",$email)) { .. }
検証のためにHTML5フォームで使用される正規表現を見つける
https://regex101.com/r/mPEKmy/1
以下のコードを使用してください。
// Variable to check
$email = "[email protected]";
// Remove all illegal characters from email
$email = filter_var($email, FILTER_SANITIZE_EMAIL);
// Validate e-mail
if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
echo("Email is a valid email address");
} else {
echo("Oppps! Email is not a valid email address");
}
特徴的なスターのコリン・エッグレスフィールドは、RomaDrama Liveでのスリル満点のファンとの出会いについて料理しました!加えて、大会での彼のINSPIREプログラム。
ノーザンエクスポージャーが90年代の最も人気のある番組の1つになった理由を確認するには、Blu-rayまたはDVDプレーヤーをほこりで払う必要があります。
ドミニカのボイリング湖は、世界で2番目に大きいボイリング湖です。そこにたどり着くまでのトレッキングは大変で長いですが、努力する価値は十分にあります。
画像クレジット:Richard Mackney / Flickrトラベリングライトは必需品だけを運ぶことを意味するかもしれませんが、デバイスを補充する方法がない外出先では、接続を維持するのが難しくなる可能性があります。それはあなたがすべての生き物の快適さやクールなガジェットを捨てる必要があるという意味ではありません、ただあなたがいくつかのより小さなものを手に入れる必要があるということです、そしておそらくあなた自身をジュースに保つためにいくつかの、例えば非正統的な充電装置を使うでしょう。
ニューヨーク州スプリンググレンにある放棄されたホモワックロッジのボーリング場。キャッツキル南部のこの地域は、ニューヨーク市からのユダヤ人の行楽客に人気があることから、かつてはボルシチベルトとして知られていました。
ブルックリンスレートブルックリンスレートのマグカップとコースターの賞賛をすでに歌っており、それらの食器製品も同様に堅実です。ブルックリンスレートは、さまざまなサイズとテクスチャのスレートの完全な採石場を販売しています。一部のオプションは赤でも利用できます。上で見ることができるように、彼らは同様にカスタマイズをします。
画像:Juan Gaertner / Shutterstock私たちの体の内部は、私たちの細胞とは何の関係もない何十億もの微生物が住んでいる本物の生態系です。これがまだ少し気になることではなかったかのように、これらの微生物の99%が研究されたことがないことがわかりました。
Zendaya shared a sweet photo in honor of boyfriend Tom Holland's 26th birthday Wednesday
シーレン「Ms.JuicyBaby」ピアソンは、先月脳卒中で入院した後、「もう一度たくさんのことをする方法を学ばなければならない」ため、言語療法を受けていることを明らかにしました。
オスカー受賞者の世紀半ばの家には、3つのベッドルーム、2つのバス、オーシャンフロントの景色があります。
Bioscoutは、農家を運転席に置くという使命を負っています。Artesian(GrainInnovate)やUniseedと並んで、最新のシードラウンドでチームを支援できることをうれしく思います。問題真菌症による重大な作物の損失は、農民にとって試練であることが証明されています。
遠隔医療は、パンデミック後の時代では新しいものではなく、時代遅れの分野でもありません。しかし、業界を詳しく見ると、需要と供給の強力な持続可能性と、米国で絶え間ない革命となる強力な潜在的成長曲線を示しています。
2021年は、世界的なベンチャーキャピタル(VC)の資金調達にとって記録的な年でした。DealStreetAsiaによると、東南アジアも例外ではなく、この地域では年間で記録的な25の新しいユニコーンが採掘されました。
計算に対する私たちの欲求とムーアの法則が提供できるものとの間には、指数関数的に増大するギャップがあります。私たちの文明は計算に基づいています—建築と想像力の現在の限界を超える技術を見つけなければなりません。