php - 使用 PHP 验证表单中的电子邮件输入

标签 php mysql html forms

我正在用 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/

相关文章:

php - 使用 PHP 在 HTML 表格中显示 MySQL 结果

php - Codeigniter - 更新查询执行成功,但 $this->db->affected_rows() 返回 false

php - 关闭 mysqli 连接会产生 : Couldn't fetch mysqli_result

mysql - 如何让 MySQL 将第二个表的查询结果存储在第一个表中?

javascript - 具有不同高度 DIV 的 block 网格

javascript - 需要将 2 个不同的 div 拉伸(stretch)到屏幕,中间有一个 div

php - 使用表连接与 2 个 MySQL 表和 DISTINCT 获取信息

mysql - 使用 SUM() 连接多个表

mysql - 使用运行 Moodle 1.9.X 的 InnoDB 的 MySql 的最佳隔离级别是多少

javascript - 多个复选框下拉 onchange() 不起作用