本文实例讲述了PHP实现的常规正则验证helper公共类。分享给大家供大家参考,具体如下:
主要代码功能: 弥补平时项目对于验证功能这块的不严谨。具体细分的常规验证, 手机号/电话/小灵通验证, 字符串长度区间合法验证, 邮箱验证, 使用正则验证数据.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
/** * * * 常规验证helper公共类 * * */ class CheckForm { //手机号/电话/小灵通 验证 public function Mobile_check( $mobile , $type = array ()) { /** * 手机号码 * 移动:134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188 * 联通:130,131,132,152,155,156,185,186 * 电信:133,1349,153,180,189 */ $res [1]= preg_match( '/^1(3[0-9]|5[0-35-9]|8[0-9])\\d{8}$/' , $mobile ); /** * 中国移动:China Mobile 11 * 134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188 */ $res [2]= preg_match( '/^1(34[0-8]|(3[5-9]|5[017-9]|8[0-9])\\d)\\d{7}$/' , $mobile ); /** * 中国联通:China Unicom * 130,131,132,152,155,156,185,186 */ $res [3]= preg_match( '/^1(3[0-2]|5[256]|8[56])\\d{8}$/' , $mobile ); /** * 中国电信:China Telecom * 133,1349,153,180,189 */ $res [4]= preg_match( '/^1((33|53|8[09])[0-9]|349)\\d{7}$/' , $mobile ); /** * 大陆地区固话及小灵通 * 区号:010,020,021,022,023,024,025,027,028,029 * 号码:七位或八位 */ $res [5]= preg_match( '/^0(10|2[0-5789]|\\d{3})-\\d{7,8}$/' , $mobile ); $type = empty ( $type ) ? array (1,2,3,4,5) : $type ; $ok = false; foreach ( $type as $key => $val ) { if ( $res [ $val ]) { $ok = true; } continue ; } if ( $mobile && $ok ) { return true; } else { return false; } } //字符串长度区间合法验证 public function Strlength_check( $str , $min =NULL, $max =NULL) { preg_match_all( "/./u" , $str , $matches ); $len = count ( $matches [0]); if ( is_null ( $min ) && ! empty ( $max ) && $len < $max ){ return false; } if ( is_null ( $max ) && ! empty ( $min ) && $len > $min ){ return false; } if ( $len < $min || $len > $max ) { return false; } return true; } //邮箱验证 public static function isEmail( $str ) { if (! $str ) { return false; } return preg_match( '#[a-z0-9&\-_.]+@[\w\-_]+([\w\-.]+)?\.[\w\-]+#is' , $str ) ? true : false; } /** * 使用正则验证数据 * @access public * @param string $rule 验证规则 * @param string $value 要验证的数据 * @return boolean */ public function regex( $rule , $value ) { $validate = array ( //字段必须,不能为空 'require' => '/\S+/' , //邮箱验证 'email' => '/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/' , //url验证 'url' => '/^http(s?):\/\/(?:[A-za-z0-9-]+\.)+[A-za-z]{2,4}(?:[\/\?#][\/=\?%\-&~`@[\]\':+!\.#\w]*)?$/' , //货币验证 'currency' => '/^\d+(\.\d{0,2})?$/' , //数字验证 'number' => '/^[-\+]?\d+(\.\d+)?$/' , //zip验证 'zip' => '/^\d{6}$/' , //整数验证 'integer' => '/^[-\+]?\d+$/' , //浮点数验证 'double' => '/^[-\+]?\d+(\.\d+)?$/' , //英文验证 'english' => '/^[A-Za-z]+$/' , 'gt0' => '/^(?!(0[0-9]{0,}$))[0-9]{1,}[.]{0,}[0-9]{0,}$/' , //合法帐号 'account' => '/^[a-zA-Z][a-zA-Z0-9_]{1,19}$/' ); // 检查是否有内置的正则表达式 if (isset( $validate [ strtolower ( $rule )])) $rule = $validate [ strtolower ( $rule )]; return preg_match( $rule , $value )===1; } function CheckPwd( $pwd , $min =NULL, $max =NULL) { if ( strlen ( $pwd )> $max || strlen ( $pwd )< $min || preg_match( "/^\d*$/" , $pwd ) || preg_match( "/^[a-z]*$/i" , $pwd )) { return false; } return true; } } |
is_null()
检测变量是否为 NULL。
希望本文所述对大家PHP程序设计有所帮助。