最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
php 检查email电子邮件函数(奇葩写法)
时间:2014-01-17 编辑:简简单单 来源:一聚教程网
以前写的一个PHP表单电子邮件发送程序,其中采用如下方法来验证电子邮件地址格式是否正确:
代码如下 | 复制代码 |
eregi("^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9_-]+.[a-z0-9_-]+.*", $email) |
后来发现类似于将.误写为,的电子邮件地址也能通过验证,例如user@126,com。经过检查,发现它实际上只验证了用户名部分,所以又在网上找到一个教程,其中给出的例子如下:
代码如下 | 复制代码 |
eregi('^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9-]+(.[a-z0-9-]+)*$',$email) |
经过检查,发现电子邮件地址user@126,com仍然能够通过它的验证。找到了一个示例:
代码如下 | 复制代码 |
eregi("^[_.0-9a-z-]+@([0-9a-z][0-9a-z-]+.)+[a-z]{2,3}$",$str) |
这个看起来更加合理一些,因为它对后缀名称进行了验证,尽管现在出现了4个字符以上的顶级域名,但是只需要稍加修改即可。不过电子邮件地址user@xxx,com 111com.net仍然能够通过验证,仔细检查后发现是因为没有对.进行转义导致。于是对它稍做修改:
代码如下 | 复制代码 |
eregi("^[_.0-9a-z-]+@([0-9a-z][0-9a-z-]+.)+[a-z]{2,4}$) |
虽然它对用户名的检查要更加宽松一些,但是现在使用它的效果似乎不错。
例1
代码如下 | 复制代码 |
function is_valid_email($email, $test_mx = false) |
例2(自己写的)
代码如下 | 复制代码 |
function is_valid_email_address($email){ |
相关文章
- PHP导出数据超时的优化建议解读 10-31
- PHP之mysql位运算解析 10-31
- Laravel实现登录跳转功能解析 10-31
- php双向队列解读 10-31
- Laravel异常上下文解决教程 10-24
- php数组查询元素位置方法介绍 10-24