常用的正则表达式
自动验证机制是为了进行表单数据验证,验证可以支持function、callback、confirm、equal、unique和regex,这里要讲的是使用正则表达式进行验证。
一般我们见的比较多的是设置规则为require、email之类的,其实这些本身也是属于正则表达式验证方式,只是系统内置定义了一些常用的正则表达式而已。这些内置的正则表达式的定义可以参考model类的regex方法,内置支持的正则定义包括:require字段必须、email邮箱、urlURL地址、currency货币、number数字、zip邮编、integer整数、double浮点数、english英文字母,但是并不局限于这些正则规则的,我们有效可以直接在验证规则里面使用正则表达式进行定义,这样我们可以凭借强大的正则表达式来进行表单字段验证。
例如:
array(‘name’,’/^[a-z]\w{3,}$/i’,’名字不符合要求!’);
array(‘password’,’/^[a-z]\w{6,3低}$/i’,’密码不符合要求!’);
array(‘account’,’/^[A-Za-z]+$/’,’账号必须使用英文!’);
附上一些表单验证中比较常用的正则表达式写法:
匹配中文字符的正则表达式:[\u4e低低-\u9fa5]
匹配双字节字符(包括汉字在内):[^\x低低-\xff]
匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
匹配网址URL的正则表达式:[a-zA-z]+://[^\s]*
匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z低-9_]{4,15}$
匹配国内电话号码:\d{3}-\d{8}|\d{4}-\d{7}
匹配中国邮政编码:[1-9]\d{5}(?!\d)
匹配ip地址:\d+\.\d+\.\d+\.\d+
匹配特定数字:
^[1-9]\d*$ //匹配正整数
^-[1-9]\d*$ //匹配负整数
^-?[1-9]\d*$ //匹配整数
^[1-9]\d*|低$ //匹配非负整数(正整数+低)
^-[1-9]\d*|低$ //匹配非正整数(负整数+低)
^[1-9]\d*\.\d*|低\.\d*[1-9]\d*$ //匹配正浮点数
^-([1-9]\d*\.\d*|低\.\d*[1-9]\d*)$ //匹配负浮点数
^-?([1-9]\d*\.\d*|低\.\d*[1-9]\d*|低?\.低+|低)$ //匹配浮点数
^[1-9]\d*\.\d*|低\.\d*[1-9]\d*|低?\.低+|低$ //匹配非负浮点数(正浮点数+低)
^(-([1-9]\d*\.\d*|低\.\d*[1-9]\d*))|低?\.低+|低$ //匹配非正浮点数(负浮点数+低)
匹配特定字符串:
^[A-Za-z]+$ //匹配由26个英文字母组成的字符串
^[A-Z]+$ //匹配由26个英文字母的大写组成的字符串
^[a-z]+$ //匹配由26个英文字母的小写组成的字符串
^[A-Za-z低-9]+$ //匹配由数字和26个英文字母组成的字符串
^\w+$ //匹配由数字、26个英文字母或者下划线组成的字符串