Heim  >  Artikel  >  Backend-Entwicklung  >  Überprüfen Sie die E-Mail-Adresse in PHP

Überprüfen Sie die E-Mail-Adresse in PHP

WBOY
WBOYnach vorne
2024-02-28 10:31:16405Durchsuche

Die Validierung von E-Mails in PHP ist eine der häufigsten Anforderungen bei der Website-Entwicklung. Eine effektive E-Mail-Verifizierung verbessert die Genauigkeit der Benutzereingaben und verhindert böswillige Registrierungen und Informationslecks. In diesem Artikel wird erläutert, wie Sie mit PHP einen einfachen und effektiven E-Mail-Verifizierungscode schreiben, um sicherzustellen, dass das vom Benutzer eingegebene E-Mail-Format der Spezifikation entspricht. Mithilfe der Anleitung in diesem Artikel können Sie die E-Mail-Verifizierungsfunktion ganz einfach implementieren und das Benutzererlebnis und die Sicherheit Ihrer Website verbessern. Der PHP-Editor Apple erklärt die Methode zur E-Mail-Verifizierung ausführlich, sodass Sie die Fähigkeiten leicht erlernen können.

Wir zeigen auch eine andere Möglichkeit, E-Mail-Adressen in FILTER_SANITIZE_EMAILFILTER_VALIDATE_EMAIL 过滤器名称 ID 以及 fiter_var()php mithilfe der -Funktion zu überprüfen. Bei dieser Methode wird zunächst die E-Mail-Adresse bereinigt und anschließend überprüft.

Wir werden eine weitere Möglichkeit zur Validierung von E-Mails in PHP mithilfe von „Regulären Ausdrücken“ behandeln. Diese Methode verwendet die Funktion , um anhand des bereitgestellten regulären Ausdrucks zu prüfen, ob die E-Mail gültig ist. preg_match()

Verwenden von
Bestätigungs-E-Mail in PHP

filter_var() 函数和 FILTER_VALIDATE_EMAIL Wir können den Filternamen

verwenden, um anzugeben, dass die E-Mail überprüft werden muss. Die Funktion übernimmt die E-Mail-Adresse als

Stringfilter_var() 函数来过滤具有特定过滤器名称的变量。FILTER_VALIDATE_EMAIL als ersten Parameter und die oben angegebene Filter-ID als zweiten Parameter. So können wir prüfen, ob die angegebene E-Mail gültig ist. Wenn die Funktion erfolgreich ist oder „false“ zurückgibt, gibt die Funktion die gefilterten Daten zurück. E-Mail gilt als gültig, nicht als Existenz einer E-Mail. Die Filter-ID validiert die E-Mail basierend auf der Syntax in RFC 822. Wir können die Verifizierung von E-Mails anhand gültiger und ungültiger E-Mails testen. Erstellen Sie beispielsweise eine Funktion

beim zweiten Anruf. validateEmail(),它接受一个参数 $email。对 $email 变量使用 filter_var() 函数,并指定过滤器 ID FILTER_VALIDATE_EMAIL 作为第二个参数。对 filter_var() 函数应用 if-else 条件。在 if 块中,显示消息说电子邮件有效,在 else 条件下,显示该电子邮件无效。在函数外,调用该函数两次。在第一个函数调用中提供参数,peter.piper@iana.orgfirst.last@example.123
Wir können davon ausgehen, dass auf die im Beispiel angegebene E-Mail-Adresse über das Formular mithilfe der Variablen

zugegriffen wird. Die Funktion im folgenden Beispiel wird zweimal aufgerufen. Der erste Anruf übergibt eine gültige E-Mail-Adresse, der zweite eine ungültige E-Mail. Die zweite E-Mail-Adresse ist ungültig, da sie eine Nummer aus der Top-Level-Domain enthält. Die Ergebnisse sind offensichtlich.

$_POST Beispielcode:

<code>
<code class="language-php hljs" data-lang="php"><span style="display:flex;"><span><span style="color:#408080;font-style:italic">#php 7.x
</span></span></span><span style="display:flex;"><span><span style="color:#666"><?</span>php
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">funct<strong class="keylink">io</strong>n</span> <span style="color:#00f">validateEmail</span>(<span style="color:#19177c">$email</span>) {
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">if</span>(filter_var(<span style="color:#19177c">$email</span>, FILTER_VALIDATE_EMAIL)) {
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> <span style="color:#ba2121">"</span><span style="color:#b68;font-weight:bold">{</span><span style="color:#19177c">$email</span><span style="color:#b68;font-weight:bold">}</span><span style="color:#ba2121">: A valid email"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span>;
</span></span><span style="display:flex;"><span>}
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">else</span> {
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> <span style="color:#ba2121">"</span><span style="color:#b68;font-weight:bold">{</span><span style="color:#19177c">$email</span><span style="color:#b68;font-weight:bold">}</span><span style="color:#ba2121">: Not a valid email"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span>;
</span></span><span style="display:flex;"><span>}
</span></span><span style="display:flex;"><span>}
</span></span><span style="display:flex;"><span>validateEmail(<span style="color:#ba2121">'peter.piper@iana.org'</span>);
</span></span><span style="display:flex;"><span>validateEmail(<span style="color:#ba2121">'first.last@example.123'</span>);
</span></span><span style="display:flex;"><span><span style="color:#bc7a00">?></span><span >
</span></span></span></code></code>

Ausgabe:

<code>
<code class="language-php hljs" data-lang="php"><span style="display:flex;"><span>phppeter<span style="color:#666">.</span>piper<span style="color:#666">@</span>iana<span style="color:#666">.</span>org<span style="color:#666">:</span> A valid email 
</span></span><span style="display:flex;"><span>first<span style="color:#666">.</span>last<span style="color:#666">@</span>example<span style="color:#666">.</span><span style="color:#666">123</span><span style="color:#666">:</span><span style="color:#008000;font-weight:bold">Not</span> a valid email
</span></span></code></code>

Überprüfen Sie die E-Mail mit der
-Funktion in PHP

FILTER_VALIDATE_EMAILFILTER_SANITIZE_EMAILfilter_var() Wir können dem ersten Ansatz folgen, indem wir im ersten Ansatz eine zusätzliche

Filternamen-ID verwenden.

FILTER_SANITIZE_EMAIL 过滤器名称 id 从电子邮件地址中删除所有非法字符。过滤器名称 id 是 filter_var() 函数中的第二个参数,其中电子邮件地址是第一个参数。该函数返回经过消毒的电子邮件。我们可以再次使用该功能来检查消毒后电子邮件地址的有效性。为此,我们可以使用 FILTER_VALIDATE_EMAIL Erstellen Sie beispielsweise eine Variable

E-Mail als Filternamen in der Funktion. Ebenso wird die Meldung angezeigt.

$email 并存储一个包含非法字符的电子邮件地址。将电子邮件 ram(.mugu)@exa//mple.org 作为字符串存储在变量中。对变量使用 filter_var() 函数,并使用 FILTER_SANITIZE_EMAIL id 作为第二个参数。将函数存储在同一个 $email 变量中。然后,像第一种方法一样应用 if-else 语句。这一次,使用 FILTER_VALIDATE_EMAIL Das folgende Beispiel verwendet eine E-Mail-Adresse mit unzulässigen Zeichen,

. Die Funktion entfernt zunächst diese Zeichen aus der E-Mail und validiert dann die E-Mail.

filter_var() 函数过滤这些字符并清理所提供的电子邮件。示例中提供的电子邮件地址包含非法字符,例如 ()// Beispielcode:

<code>
<code class="language-php hljs" data-lang="php"><span style="display:flex;"><span><span style="color:#408080;font-style:italic">#php 7.x
</span></span></span><span style="display:flex;"><span><span style="color:#666"><?</span>php
</span></span><span style="display:flex;"><span><span style="color:#19177c">$email</span> <span style="color:#666">=</span> <span style="color:#ba2121">"ram(.mugu)@exa//mple.org"</span>;
</span></span><span style="display:flex;"><span><span style="color:#19177c">$email</span> <span style="color:#666">=</span> filter_var(<span style="color:#19177c">$email</span>, FILTER_SANITIZE_EMAIL);
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">if</span>(filter_var(<span style="color:#19177c">$email</span>, FILTER_VALIDATE_EMAIL)) {
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> <span style="color:#ba2121">"</span><span style="color:#b68;font-weight:bold">{</span><span style="color:#19177c">$email</span><span style="color:#b68;font-weight:bold">}</span><span style="color:#ba2121">: A valid email"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span>;
</span></span><span style="display:flex;"><span>}
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">else</span>{
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> <span style="color:#ba2121">"</span><span style="color:#b68;font-weight:bold">{</span><span style="color:#19177c">$email</span><span style="color:#b68;font-weight:bold">}</span><span style="color:#ba2121">:Not a valid email"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span>;
</span></span><span style="display:flex;"><span>}
</span></span><span style="display:flex;"><span><span style="color:#bc7a00">?></span><span >
</span></span></span></code></code>

Ausgabe:

<code>
<code class="language-php hljs" data-lang="php"><span style="display:flex;"><span>ram<span style="color:#666">.</span>mugu<span style="color:#666">@</span>example<span style="color:#666">.</span>org<span style="color:#666">:</span> A valid email
</span></span></code></code>

使用 preg_match() 函数根据正则表达式验证电子邮件

我们可以使用 preg_match() 函数来验证 PHP 中的电子邮件地址。此方法使用正则表达式作为电子邮件的验证规则。我们可以自己创建正则表达式并定义有效电子邮件的规则。preg_match() 函数接受两个参数,其中第一个是正则表达式,第二个是要检查的电子邮件。我们可以使用三元运算符和函数一起检查电子邮件的有效性。

例如,创建两个变量 $email_first$email_secon,并在这些变量中存储两个电子邮件地址。首先存储有效的电子邮件 firstlast11@gmail.com,然后存储无效的电子邮件 firstlast@11gmail,com。编写一个带有一个参数的函数 validateEmail()。命名参数 $email。在函数内部,在 $regex 变量中编写一个正则表达式,如示例代码所示。然后编写一个三元运算符,其中要检查的条件是 preg_match() 函数。将 $regex 作为第一个参数,将 $email 作为第二个参数。当条件为真时打印电子邮件有效的消息,当条件为假时打印电子邮件无效的消息。回显整个三元表达式。在函数外,调用 validateEmail() 函数两次。在第一个函数调用中使用 $email_first 变量,在第二个函数调用中使用 $email_second 变量。

在下面的示例中,我们编写了一个正则表达式,用于创建验证电子邮件的规则。有效的电子邮件包含收件人姓名、@ 符号、域和顶级域。上面创建的正则表达式接受收件人姓名作为字母数字值。字母表由大写字母和小写字母组成。它也接受一个句点。电子邮件必须有 @ 符号。该域仅包含字母。然后电子邮件应该有一个句点。顶级域应该只由字母组成,并且长度应该是两个或三个。正则表达式是基于此规则创建的。第一封电子邮件是有效的,因为它满足所有规则,但第二封电子邮件无效。无效,因为域名中有数字,顶级域名前没有句号。

示例代码:

<code>
<code class="language-php hljs" data-lang="php"><span style="display:flex;"><span><span style="color:#408080;font-style:italic"># php 7.x
</span></span></span><span style="display:flex;"><span><span style="color:#666"><?</span>php
</span></span><span style="display:flex;"><span><span style="color:#19177c">$email_first</span> <span style="color:#666">=</span> <span style="color:#ba2121">'firstlast11@gmail.com'</span>;
</span></span><span style="display:flex;"><span><span style="color:#19177c">$email_second</span> <span style="color:#666">=</span><span style="color:#ba2121">'firstlast@11gmail,com'</span>;
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">function</span> <span style="color:#00f">validateEmail</span>(<span style="color:#19177c">$email</span>) {
</span></span><span style="display:flex;"><span><span style="color:#19177c">$regex</span> <span style="color:#666">=</span> <span style="color:#ba2121">"/^([a-zA-Z0-9\.]+@+[a-zA-Z]+(\.)+[a-zA-Z]{2,3})$/"</span>;
</span></span><span style="display:flex;"><span><span style="color:#008000;font-weight:bold">echo</span> preg_match(<span style="color:#19177c">$regex</span>, <span style="color:#19177c">$email</span>) <span style="color:#666">?</span> <span style="color:#ba2121">"The email is valid"</span><span style="color:#666">.</span><span style="color:#ba2121">"<br>"</span> <span style="color:#666">:</span><span style="color:#ba2121">"The email is not valid"</span>;
</span></span><span style="display:flex;"><span>}
</span></span><span style="display:flex;"><span>validateEmail(<span style="color:#19177c">$email_first</span>);
</span></span><span style="display:flex;"><span>validateEmail(<span style="color:#19177c">$email_second</span>);
</span></span><span style="display:flex;"><span><span style="color:#bc7a00">?></span><span >
</span></span></span></code></code>

输出:

<code>
<code class="language-text hljs" data-lang="text"><span style="display:flex;"><span>The email is valid 
</span></span><span style="display:flex;"><span>The email is not valid
</span></span></code></code>

Das obige ist der detaillierte Inhalt vonÜberprüfen Sie die E-Mail-Adresse in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:lsjlt.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen
Vorheriger Artikel:Richtig und falsch in PHPNächster Artikel:Richtig und falsch in PHP