php表单习惯用的正则表达式
程序员文章站
2022-11-02 19:20:37
php表单常用正则表达式,代码如下所示:
function is_email($str){
//检验email
return preg_match("/^...
php表单常用正则表达式,代码如下所示:
function is_email($str){ //检验email return preg_match("/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/", $str); } function is_url($str){ //检验网址 return preg_match("/^http:\/\/[a-za-z0-9]+\.[a-za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"]) *$/", $str); } function is_qq($str){ //检验qq return preg_match("/^[1-9]\d{4,8}$/", $str); } function is_zip($str){ //检验邮编 return preg_match("/^[1-9]\d{5}$/", $str); } function is_idcard($str){ //检验身份证 return preg_match("/^\d{15}(\d{2}[a-za-z0-9])?$/", $str); } function is_chinese($str){ 检验是否是中文 return ereg("^[".chr(0xa1)."-".chr(0xff)."]+$",$str); } function is_english($str){ //检验是否是英文 return preg_match("/^[a-za-z]+$/", $str); } function is_mobile($str){ //检验是否是手机 return preg_match("/^((\(\d{3}\))|(\d{3}\-))?13\d{9}$/", $str); } function is_phone($str){ //建云那是否是电话 return preg_match("/^((\(\d{3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}$/", $str); } function is_safe($str){ return (preg_match("/^(([a-z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|. {0,5})$|\s/", $str) != 0); } }
ps:下面再给大家分享一段代码
<?php /** * @description: 正则表达式匹配 */ class regex { /** * @手机号 */ public static function phone($subject) { $pattern='/^(0|86|17951)?(13[0-9]|15[012356789]|1[78][0-9]|14[57])[0-9]{8}$/'; return regex::publicmethod($pattern, $subject); } /** * @数字 */ public static function number($subject) { $pattern='/^[0-9]+$/'; return regex::publicmethod($pattern, $subject); } /** * @年份 格式:yyyy */ public static function year($subject) { $pattern='/^(\d{4})$/'; return regex::publicmethod($pattern, $subject); } /** * @月份 格式:mm */ public static function month($subject) { $pattern='/^0?([1-9])$|^(1[0-2])$/'; return regex::publicmethod($pattern, $subject); } /** * @日期 格式:yyyy-mm-dd */ public static function day($subject) { $pattern='/^(\d{4})-(0?\d{1}|1[0-2])-(0?\d{1}|[12]\d{1}|3[01])$/'; return regex::publicmethod($pattern, $subject); } /** * @日期时间 格式:yyyy-mm-dd hh:ii:ss */ public static function datetime($subject) { $pattern='/^(\d{4})-(0?\d{1}|1[0-2])-(0?\d{1}|[12]\d{1}|3[01])\s(0\d{1}|1\d{1}|2[0-3]):[0-5]\d{1}:([0-5]\d{1})$/'; return regex::publicmethod($pattern, $subject); } /** * @邮箱 */ public static function email($subject) { $pattern='/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/'; return regex::publicmethod($pattern, $subject); } /** * @邮编 */ public static function postcode($subject) { $pattern='/[1-9]\d{5}(?!\d)/'; return regex::publicmethod($pattern, $subject); } /** * @有效图片地址 */ public static function photo($subject) { $pattern='/\b(([\w-]+:\/\/?|www[.])[^\s()<>]+(?:\([\w\d]+\)|([^[:punct:]\s]|\/)))/'; return regex::publicmethod($pattern, $subject); } /** * @url地址 */ public static function urladdress($subject) { $pattern='/\b(([\w-]+:\/\/?|www[.])[^\s()<>]+(?:\([\w\d]+\)|([^[:punct:]\s]|\/)))/'; return regex::publicmethod($pattern, $subject); } /** * @有效http地址 */ public static function effectivehttp($subject) { $pattern='/\b(([\w-]+:\/\/?|www[.])[^\s()<>]+(?:\([\w\d]+\)|([^[:punct:]\s]|\/)))/'; return regex::publicmethod($pattern, $subject); } /** * @身份证 */ public static function identity($subject) { $pattern='/(^\d{15}$)|(^\d{17}([0-9]|x)$)/'; return regex::publicmethod($pattern, $subject); } /** * @ipv4 */ public static function ipv4($subject) { $pattern='/^(((\d{1,2})|(1\d{2})|(2[0-4]\d)|(25[0-5]))\.){3}((\d{1,2})|(1\d{2})|(2[0-4]\d)|(25[0-5]))$/'; return regex::publicmethod($pattern, $subject); } /** * @ipv6 */ public static function ipv6($subject) { $pattern='/^([\da-fa-f]{1,4}:){7}[\da-fa-f]{1,4}$/'; return regex::publicmethod($pattern, $subject); } /** * @匹配正则公共方法 */ public static function publicmethod($pattern, $subject){ if(preg_match($pattern, $subject)){ return true; } return false; } }
好了,内容就这么多少,希望对大家有所帮助!
上一篇: CAD2014图层无法删除怎么办? CAD删除顽固图层的教程
下一篇: iptables中文手册