我正在用 PHP 创建一个表单,其中包含一个名为 email 的字段,用户需要在其中输入他/她的电子邮件 ID。为了确保输入的邮件 ID 在语法方面是真实的(例如 username_123@domain.com
是有效的),我需要对其附加某种验证。我发现情况很模糊,因为我不明白如何检查输入的邮件 ID 是否包含 @
符号等。请帮忙。谢谢。 :)
最佳答案
最好的解决办法就是:
if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
...
}
让 PHP 为您处理繁重的工作。否则,如果您想严格正确并自己直接使用正则表达式,您将陷入这种怪诞:
(?:[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|"(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21\x23-\x5b\x5d-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])*")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\[(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[a-z0-9-]*[a-z0-9]:(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21-\x5a\x53-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])+)\])
严格遵守 RFC2822。
关于php - 使用 PHP 验证表单中的电子邮件输入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7519801/