PHP常用正则(手机号、座机、邮箱、身份证及手机号截取)

 更新时间:2016年11月25日 15:42  点击:1579
主要分享php中手机号、座机、邮箱、身份证(15或18位)、手机号截取(中间四位为*)的正则表达式,都是自己工作收集而来。如果有不对的地方。欢迎提出!
 代码如下 复制代码

//验证手机号
$match = '/^((13[0-9])|(15[^4,\d])|(18[0,5-9]))[0-9]{8}$/';
//验证座机
$match = '/^(0[0-9]{2,3}-)?([2-9][0-9]{6,7})+(-[0-9]{1,4})?$/';
//验证身份证号15或18位
$match = '/(^d{15}$)|(^d{17}(d|X|x)$)/';
//Email验证
$match = '/^w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$/';
//将手机号中间转换为 * 号
$tel = 18600000000;
$pattern = '/(d{3})d{4}(d{3})/';
$replacement = "$1****$2";
echo preg_replace($pattern,$replacement,$tel);

目前最为流行的微信游戏了,就是抽奖活动,下面我看一站长整理了这款抽奖源码出来,下面我也转过来与各位朋友分享。

在做微信的过程中用到了微信抽奖,看了其他的作者都只是吧微信抽奖的页面共享出来了。我现在把转盘抽奖程序和微信抽奖页面都共享出来,有需要的自己把两者组合一下即可。

微信(weixin)大转盘抽奖

部份源码:配置文件

 代码如下 复制代码
<?php
return array (
  'DB_TYPE' => 'mysql',
  'DB_HOST' => '127.0.0.1',
  'DB_NAME' => 'ites',
  'DB_USER' => 'root',
  'DB_PWD' => '111111',
  'DB_PORT' => 3306,
  'DB_PREFIX' => 'it_',
  'APP_DEBUG' => 1,
  'SHOW_ERROR_MSG' => 1,
  'SHOW_PAGE_TRACE' => 1,
  'DATA_CACHE_TYPE' => 'Redis',
  'REDIS_HOST' => '127.0.0.1',
  'REDIS_PORT' => 6379,
  'DATA_CACHE_TIME' => 3600,
  'URL_CASE_INSENSITIVE' => true,
  'TMPL_STRIP_SPACE' => false,
  'URL_HTML_SUFFIX' => '',
  'SITE_NAME' => '11111',
  'SITE_URL' => 'http://www.111cn.net/',
  'WECHAT_TOKEN' => '你的',
  'WECHAT_APPID' => '你的',
  'WECHAT_APPSECRET' => '你的',
  'DATA_AUTH_KEY' => 'abcdddd',
);
?>

commond.php文件

 代码如下 复制代码

<?php
function isMobile($mobile) {
 return preg_match("/^(?:13d|14d|15d|18[0123456789])-?d{5}(d{3}|*{3})$/", $mobile);
}

function isEmail($email) {
 return strlen($email) > 6 && preg_match("/^[w-.]+@[w-.]+(.w+)+$/", $email);
}

/**
 * 发送HTTP请求方法,目前只支持CURL发送请求
 * @param  string $url    请求URL
 * @param  array  $params 请求参数
 * @param  string $method 请求方法GET/POST
 * @return array  $data   响应数据
 */
function http($url, $params, $method = 'GET', $header = array(), $multi = false){
 $opts = array(
   CURLOPT_TIMEOUT        => 30,
   CURLOPT_RETURNTRANSFER => 1,
   CURLOPT_SSL_VERIFYPEER => false,
   CURLOPT_SSL_VERIFYHOST => false,
   CURLOPT_HTTPHEADER     => $header
 );

 /* 根据请求类型设置特定参数 */
 switch(strtoupper($method)){
  case 'GET':
   $opts[CURLOPT_URL] = $url . '?' . http_build_query($params);
   break;
  case 'POST':
   //判断是否传输文件
   //$params = $multi ? $params : http_build_query($params);
   $opts[CURLOPT_URL] = $url;
   $opts[CURLOPT_POST] = 1;
   $opts[CURLOPT_POSTFIELDS] = $params;
   break;
  default:
   throw new Exception('不支持的请求方式!');
 }

 /* 初始化并执行curl请求 */
 $ch = curl_init();
 curl_setopt_array($ch, $opts);
 $data  = curl_exec($ch);
 $error = curl_error($ch);
 curl_close($ch);
 if($error) throw new Exception('请求发生错误:' . $error);
 return  $data;
}

/**
 * 不转义中文字符和/的 json 编码方法
 * @param array $arr 待编码数组
 * @return string
 */
function jsencode($arr) {
 $str = str_replace ( "\/", "/", json_encode ( $arr ) );
 $search = "#\u([0-9a-f]+)#ie";
 
 if (strpos ( strtoupper(PHP_OS), 'WIN' ) === false) {
  $replace = "iconv('UCS-2BE', 'UTF-8', pack('H4', '\1'))";//LINUX
 } else {
  $replace = "iconv('UCS-2', 'UTF-8', pack('H4', '\1'))";//WINDOWS
 }
 
 return preg_replace ( $search, $replace, $str );
}

// 数据保存到文件
function data2file($filename, $arr=''){
 if(is_array($arr)){
  $con = var_export($arr,true);
  $con = "<?php return $con; ?>";
 } else{
  $con = $arr;
  $con = "<?php $con; ?>";
 }
 write_file($filename, $con);
}

/**
 * 系统加密方法
 * @param string $data 要加密的字符串
 * @param string $key  加密密钥
 * @param int $expire  过期时间 单位 秒
 * @return string
 * @author winky
 */
function encrypt($data, $key = '', $expire = 0) {
    $key  = md5(empty($key) ? C('DATA_AUTH_KEY') : $key);
    $data = base64_encode($data);
    $x    = 0;
    $len  = strlen($data);
    $l    = strlen($key);
    $char = '';

    for ($i = 0; $i < $len; $i++) {
        if ($x == $l) $x = 0;
        $char .= substr($key, $x, 1);
        $x++;
    }

    $str = sprintf('%010d', $expire ? $expire + time():0);

    for ($i = 0; $i < $len; $i++) {
        $str .= chr(ord(substr($data, $i, 1)) + (ord(substr($char, $i, 1)))%256);
    }
    return str_replace(array('+','/','='),array('-','_',''),base64_encode($str));
}

/**
 * 系统解密方法
 * @param  string $data 要解密的字符串 (必须是encrypt方法加密的字符串)
 * @param  string $key  加密密钥
 * @return string
 * @author winky
 */
function decrypt($data, $key = ''){
    $key    = md5(empty($key) ? C('DATA_AUTH_KEY') : $key);
    $data   = str_replace(array('-','_'),array('+','/'),$data);
    $mod4   = strlen($data) % 4;
    if ($mod4) {
       $data .= substr('====', $mod4);
    }
    $data   = base64_decode($data);
    $expire = substr($data,0,10);
    $data   = substr($data,10);

    if($expire > 0 && $expire < time()) {
        return '';
    }
    $x      = 0;
    $len    = strlen($data);
    $l      = strlen($key);
    $char   = $str = '';

    for ($i = 0; $i < $len; $i++) {
        if ($x == $l) $x = 0;
        $char .= substr($key, $x, 1);
        $x++;
    }

    for ($i = 0; $i < $len; $i++) {
        if (ord(substr($data, $i, 1))<ord(substr($char, $i, 1))) {
            $str .= chr((ord(substr($data, $i, 1)) + 256) - ord(substr($char, $i, 1)));
        }else{
            $str .= chr(ord(substr($data, $i, 1)) - ord(substr($char, $i, 1)));
        }
    }
    return base64_decode($str);
}

function getTaskStatusStr($status = 0,$type = 'apply' , $company = ''){
 if ($type == 'comment') return '尚未作出评价';
 switch ($status) {
  case 0:
   return $type == 'apply' ? '已发出任务申请' : $company.'对你发出了任务邀请';
  break;
  case 1:
   return $type == 'apply' ? '企业已通过申请' : '已同意企业的邀请';
  break;  
  case 2:
   return $type == 'apply' ? '企业已忽略你的申请' : '你已经忽略企业的邀请';
  break;
  case 3:
   return $type == 'apply' ? '你已完成该任务' : '该任务已经完成';
  break;  
  default:
   return '未知的状态';
  break;
 }
}


function getArea($cache = true){
 $area = S ( 'S_Area' );
 if (empty ( $area ) || ! $cache) {
  // 缓存不存在,或者参数读取缓存。
  $areaModel = D('Area');
  $area = $areaModel -> where ('status = 3')->order ( 'sort,itemid' )->getField('itemid,title,pid,arrparentid,child');
  //把市的省拚出来
  foreach ($area as $k=>$v){
   //如果是顶级
   if ($v['pid']==0){
    $areaArr[$v['itemid']]['itemid'] = $v['itemid'];
    $areaArr[$v['itemid']]['title'] = $v['title'];
    $areaArr[$v['itemid']]['pid'] = $v['pid'];
    $areaArr[$v['itemid']]['arrparentid'] = $v['arrparentid'];
    $areaArr[$v['itemid']]['child'] = $v['child'];
    //上级
    $areaArr[$v['itemid']]['upitemid'] = $v['itemid'];
    $areaArr[$v['itemid']]['uptitle'] = $v['title'];
   }
   //查出上级的名称和ID
   else {
    $areaArr[$v['itemid']]['itemid'] = $v['itemid'];
    $areaArr[$v['itemid']]['title'] = $v['title'];
    $areaArr[$v['itemid']]['pid'] = $v['pid'];
    $areaArr[$v['itemid']]['arrparentid'] = $v['arrparentid'];
    $areaArr[$v['itemid']]['child'] = $v['child'];
    //上级
    $areaArr[$v['itemid']]['upitemid'] = $area[$v['pid']]['itemid'];
    $areaArr[$v['itemid']]['uptitle'] = $area[$v['pid']]['title'];
   }
  }
  $area = $areaArr;
  S ( 'S_Area' , $area );
 }
 return $area;
}

?>

源码下载地址

http://file.111cn.net/upload/2014/3/wx.rar

 

我们常用做商城时会希望把用户输入的数字转换在RMB大写形式了,下面我整理了几个可以处理万亿级的数字转换例子,大家一起来看看这些例子吧。

例子1

 代码如下 复制代码

function change_num($num)
 {
 $d = array('零','壹','贰','叁','肆','伍','陆','柒','捌','玖');
 $e = array('元','拾','佰','仟','万','拾万','佰万','仟万','亿','拾亿','佰亿','仟亿','万亿');
 $p = array('分','角');
 $zheng='整'; //追加"整"字
 $final = array(); //结果
 $inwan=0; //是否有万
 $inyi=0; //是否有亿
 $len_pointdigit=0; //小数点后长度
 $y=0;
 if($c = strpos($num, '.')) //有小数点,$c为小数点前有几位数
 {
 $len_pointdigit = strlen($num)-strpos($num, '.')-1; // 判断小数点后有几位数
 if($c>13) //简单的错误处理
 {
 echo "数额太大,已经超出万亿.";
 die();
 }
 elseif($len_pointdigit>2) //$len_pointdigit小数点后有几位
 {
 echo "小数点后只支持2位.";
 die();
 }
 }
 else //无小数点
 {
 $c = strlen($num);
 $zheng = '整';
 }
 for($i=0;$i<$c;$i++) //处理整数部分
 {
 $bit_num = substr($num, $i, 1); //逐字读取 左->右
 if($bit_num!=0 || substr($num, $i+1, 1)!=0) //当前是零 下一位还是零的话 就不显示
 @$low2chinses = $low2chinses.$d[$bit_num];
 if($bit_num || $i==$c-1)
 @$low2chinses = $low2chinses.$e[$c-$i-1];
 }
 for($j=$len_pointdigit; $j>=1; $j--) //处理小数部分
 {
 $point_num = substr($num, strlen($num)-$j, 1); //逐字读取 左->右
 if($point_num != 0)
 @$low2chinses = $low2chinses.$d[$point_num].$p[$j-1];
 //if(substr($num, strlen($num)-2, 1)==0 && substr($num, strlen($num)-1, 1)==0) //小数点后两位都是0
 }
 $chinses = str_split($low2chinses,2); //字符串转换成数组
 //print_r($chinses);
 for($x=sizeof($chinses)-1;$x>=0;$x--) //过滤无效的信息
 {
 if($inwan==0&&$chinses[$x]==$e[4]) //过滤重复的"万"
 {
 $final[$y++] = $chinses[$x];
 $inwan=1;
 }
 if($inyi==0&&$chinses[$x]==$e[8]) //过滤重复的"亿"
 {
 $final[$y++] = $chinses[$x];
 $inyi=1;
 $inwan=0;
 }
 if($chinses[$x]!=$e[4]&&$chinses[$x]!=$e[8]) //进行整理,将最后的值赋予$final数组
 $final[$y++] = $chinses[$x];
 }
 $newstring=(array_reverse($final)); //$final为倒数组,$newstring为正常可以使用的数组
 $nstring=join($newstring); //数组变成字符串
 if(substr($num,-2,1)==0 && substr($num,-1)<>0) //判断原金额角位为0 ? 分位不为0 ?
 {
 $nstring=substr($nstring,0,(strlen($nstring)-4))."零".substr($nstring,-4,4); //这样加一个零字
 }
 $fen="分";
 $fj=substr_count($nstring, $fen); //如果没有查到分这个字
 return $nstring=($fj==0)?$nstring.$zheng:$nstring; //就将"整"加到后面
 }


例子2

 1.支持天文数字,整数位理论上可以无限的长;
    2.支持小数,对于货币,一般精确到小数后两位,可以设置小数位是否四舍五入;
    3.支持自定义货币单位,有的系统要求大写是"圆",有的要求是"元",可以自定义;
    4.支持整数以0结束并含有小数的数字自定义末尾补"零",比如有的系统要求1960.30这样的数字转大写之后是"壹仟玖佰陆拾元叁角",而有的系统则要求"壹仟玖佰陆拾元零叁角",这两种情况按"正确填写票据和结算凭证的基本规定"都是正确的,现在可已自定义。

 

 代码如下 复制代码

 <?php
    /**
     * 人民币小写转大写
     *
     * @param string $number 数值
     * @param string $int_unit 币种单位,默认"元",有的需求可能为"圆"
     * @param bool $is_round 是否对小数进行四舍五入
     * @param bool $is_extra_zero 是否对整数部分以0结尾,小数存在的数字附加0,比如1960.30,
     *             有的系统要求输出"壹仟玖佰陆拾元零叁角",实际上"壹仟玖佰陆拾元叁角"也是对的
     * @return string
     * @site www.111cn.net     */
    function num2rmb($number = 0, $int_unit = '元', $is_round = TRUE, $is_extra_zero = FALSE)
    {
        // 将数字切分成两段
        $parts = <A class=infotextkey href="http://www." target=_blank>explode</A>('.', $number, 2);
        $int = <A class=infotextkey href="http://www.111cn.net/" target=_blank>isset</A>($parts[0]) ? strval($parts[0]) : '0';
        $dec = isset($parts[1]) ? strval($parts[1]) : '';

        // 如果小数点后多于2位,不四舍五入就直接截,否则就处理
        $dec_len = strlen($dec);
        if (isset($parts[1]) && $dec_len > 2)
        {
            $dec = $is_round
                    ? substr(strrchr(strval(round(floatval("0.".$dec), 2)), '.'), 1)
                    : substr($parts[1], 0, 2);
        }

        // 当number为0.001时,小数点后的金额为0元
        if(empty($int) && empty($dec))
        {
            return '零';
        }

        // 定义
        $chs = array('0','壹','贰','叁','肆','伍','陆','柒','捌','玖');
        $uni = array('','拾','佰','仟');
        $dec_uni = array('角', '分');
        $exp = array('', '万');
        $res = '';

        // 整数部分从右向左找
        for($i = strlen($int) - 1, $k = 0; $i >= 0; $k++)
        {
            $str = '';
            // 按照中文读写习惯,每4个字为一段进行转化,i一直在减
            for($j = 0; $j < 4 && $i >= 0; $j++, $i--)
            {
                $u = $int{$i} > 0 ? $uni[$j] : ''; // 非0的数字后面添加单位
                $str = $chs[$int{$i}] . $u . $str;
            }
            //echo $str."|".($k - 2)."<br>";
            $str = rtrim($str, '0');// 去掉末尾的0
            $str = preg_replace("/0+/", "零", $str); // 替换多个连续的0
            if(!isset($exp[$k]))
            {
                $exp[$k] = $exp[$k - 2] . '亿'; // 构建单位
            }
            $u2 = $str != '' ? $exp[$k] : '';
            $res = $str . $u2 . $res;
        }

        // 如果小数部分处理完之后是00,需要处理下
        $dec = rtrim($dec, '0');

        // 小数部分从左向右找
        if(!empty($dec))
        {
            $res .= $int_unit;

            // 是否要在整数部分以0结尾的数字后附加0,有的系统有这要求
            if ($is_extra_zero)
            {
                if (substr($int, -1) === '0')
                {
                    $res.= '零';
                }
            }

            for($i = 0, $cnt = strlen($dec); $i < $cnt; $i++)
            {
                $u = $dec{$i} > 0 ? $dec_uni[$i] : ''; // 非0的数字后面添加单位
                $res .= $chs[$dec{$i}] . $u;
            }
            $res = rtrim($res, '0');// 去掉末尾的0
            $res = preg_replace("/0+/", "零", $res); // 替换多个连续的0
        }
        else
        {
            $res .= $int_unit . '整';
        }
        return $res;
    }

    echo "<pre>";
    $number = "1000000000000000012345678900.501";
    echo $number.":".num2rmb($number);
    echo "n";
    $number = "1960.30";
    echo $number.":".num2rmb($number);
    echo "n";
    $number = "1960.30";
    echo $number.":".num2rmb($number, "圆", true, true);
    echo "n";
    $number = "123456789.005";
    echo $number.":".num2rmb($number);
    echo "n";
    $number = "123456789.005";
    echo $number.":".num2rmb($number, "元", false);
    echo "n";
    $number = "10000000000000000060009.101";
    echo $number.":".num2rmb($number);
    echo "n";
    $number = "1680.32";
    echo $number.":".num2rmb($number);
?>

例子3

看上面的个人更喜欢下面这个

 代码如下 复制代码

//把数字金额转换成中文大写数字的函数
function num2rmb ($num){
 $c1="零壹贰叁肆伍陆柒捌玖";
 $c2="分角元拾佰仟万拾佰仟亿";

 $num=round($num,2);
 $num=$num*100;
 $NewNum = ceil($num);
 if(strlen($NewNum)>10){
 return "金额太大";
 }

 $i=0;
 $c="";

 while (1){
 if($i==0){
 $n=substr($num,strlen($num)-1,1);
 }else{
 $n=$num %10;
 }

 $p1=substr($c1,2*$n,2);

 $p2=substr($c2,2*$i,2);
 if($n!='0' || ($n=='0' &&($p2=='亿' || $p2=='万' || $p2=='元' ))){
 $c=$p1.$p2.$c;
 }else{
 $c=$p1.$c;
 }

 $i=$i+1;
 $num=$num/10;
 $num=(int)$num;

 if($num==0){
 break;
 }
 }//end of while| here, we got a chinese string with some useless character

 //we chop out the useless characters to form the correct output
 $j = 0;
 $slen=strlen($c);
 while ($j< $slen) {
 $m = substr($c,$j,4);

 if ($m=='零元' || $m=='零万' || $m=='零亿' || $m=='零零'){
 $left=substr($c,0,$j);
 $right=substr($c,$j+2);
 $c = $left.$right;
 $j = $j-2;
 $slen = $slen-2;
 }
 $j=$j+2;
 }

 if(substr($c,strlen($c)-2,2)=='零'){
 $c=substr($c,0,strlen($c)-2);
 } // if there is a '0' on the end , chop it out

 return $c;
}// end of function

php生成二维码一般都是使用用一些插件来实现了,下面我们利用phpqrcode来给各位朋友实现生成二维码的同时现加一个水印logo上去,下面看例子。

给手机app作一个二维码的接口,要求支持iso,android,win8手机,找了第三个方工具phpqrcode。

1,下载地址

源码下载:https://github.com/t0k4rt/phpqrcode


2,加水印图片,片段代码

 代码如下 复制代码

    $logo = 'logo.png';

    if(is_file($logo))
    {
        $QR = imagecreatefromstring(file_get_contents($filename));
        $logo = imagecreatefromstring(file_get_contents($logo));
        $QR_width = imagesx($QR);
        $QR_height = imagesy($QR);
        $logo_width = imagesx($logo);
        $logo_height = imagesy($logo);
        $logo_qr_width = $QR_width / 5;
        $scale = $logo_width / $logo_qr_width;
        $logo_qr_height = $logo_height / $scale;
        $from_width = ($QR_width - $logo_qr_width) / 2;
        imagecopyresampled($QR, $logo, $from_width, $from_width, 0, 0, $logo_qr_width, $logo_qr_height, $logo_width, $logo_height);
        imagepng($QR,$filename);
    }

 

现在有很多朋友在做网站安全验证时会把session存放在cookie中,这样我们就对一些数据进行加密处理,那么他们这样做的优缺点是什么及有那些安全问题呢?下面我们一起来对比一下。

这篇文章不是讨论session,也不是cookie,现在很多网站都是讲session放cookie中,叫做cookie based session,下面就来讨论下cookie based session的优缺点:

优点:

1.减轻服务器压力,如PHP session默认是文件存储格式的,这样就会较少磁盘压力,不会给磁盘造成较多的碎片。
2.你在做集群的时候,是不是要做session同步的问题,cookie based session后就免去了。

缺点:

1.同一个用户,可能在多个地方登录,你也无从判断谁是真实有效用户。
2.session记录在cookie放本地,可能被hacer获取,通过anehta可以将cookie持久化,使登录状态永久有效,当然你可以再记录cookie的时候记录时间戳,在服务器端验证有效期。
个人建议:
从安全性上来说只要处理得当,session和cookie相差无几,另外还要考虑cookie的存储量,一些重要信息如用户信息或权限信息最好不要放cookie

session和cookie谁更安全

就个人而言,我觉得session更安全一点,我以下几点看法。

1,如果session和cookie一样安全的话,二者就没有并要同时存在了,只要cookie就好了,让客户端来分提服务器的负担,并且对于用户来说又是透明的。何乐而不为呢。

2,session的sessionID是放在cookie里,要想功破session的话,第一要功破cookie。功破cookie后,你要得到 sessionID,sessionID是要有人登录,或者启动session_start才会有,你不知道什么时候会有人登录。第二,sessionID是加密的,第二次session_start的时候,前一次的sessionID就没有用了,session过期时sessionid也会失效,想在短时间内功破加了密的 sessionID很难。session是针对某一次通信而言,会话结束session也就随着消失了,而真正的cookie存在于客户端硬盘上的一个文本文件,谁安全很显然了。

[!--infotagslink--]

相关文章

  • php身份证校验码的计算例子

    下面来给各位同学介绍一个php身份证校验码的计算例子,希望本函数代码能帮助到各位同学哦。 例子 代码如下 复制代码 public function id_ver...2016-11-25
  • phpexcel导出数据身份证后四位0000解决办法

    在php中我们如果要导入excel数据我们通常会使用phpexcel插件了,但是有朋友会发与使用phpexcel导出数据出现身份证后四位是0000情况了,下面我们就来看解决办法。 最...2016-11-25
  • 一个关于JS正则匹配的踩坑记录

    这篇文章主要给大家介绍了一个关于JS正则匹配的踩坑记录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-04-13
  • 怎么查询自己的联通手机号码是否已经实名认证(实名制)?

    怎么查询自己的联通手机号码是否已经实名认证?现在手机一批一批的开始实名制了,自己的手机号买的时候没有实名认证,怎么才能知道自己的手机是否被知名认证了呢?认证以后就不能充话费打电话了,下面我们们一起来看看两种查看方法...2016-07-04
  • JS基于正则截取替换特定字符之间字符串操作示例

    这篇文章主要介绍了JS基于正则截取替换特定字符之间字符串操作方法,结合具体实例形式分析了JS基于正则实现针对特殊字符、数字等字符串类型的截取操作相关技巧,需要的朋友可以参考下...2017-02-08
  • js正则学习小记之匹配字符串字面量

    关于匹配字符串问题,有很多种类型,今天讨论 js 代码里的字符串匹配,因为我想学完之后写个语法高亮练手,所以用js代码当作例子...2021-05-07
  • C#使用正则表达式过滤html标签

    最近在开发一个项目,其中有需求要求我们把一段html转换为一般文本返回,使用正则表达式是明智的选择,下面小编给介绍下C#使用正则表达式过滤html标签,需要的朋友参考下...2020-06-25
  • js 正则学习小记之匹配字符串字面量优化篇

    昨天在《js 正则学习小记之匹配字符串字面量》谈到 /"(?:\\.|[^"])*"/ 是个不错的表达式,因为可以满足我们的要求,所以这个表达式可用,但不一定是最好的...2021-05-07
  • 浅谈JS正则RegExp对象

    这篇文章主要介绍JS正则RegExp对象,正则表达式是描述字符模式的对象,用于对字符串模式匹配及检索替换,是对字符串执行模式匹配的强大工具。下面就来看具体详情,需要的朋友可以参考一下...2021-10-21
  • OpenResty中正则模式匹配的2种方法详解

    在 OpenResty 中,同时存在两套正则表达式规范:Lua 语言的规范和 Nginx 的规范,下面这篇文章主要给大家介绍了关于OpenResty中正则模式匹配的2种方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考下。...2020-06-30
  • 浅谈C#手机号换成111XXXX1111 这种显示的解决思路

    下面小编就为大家带来一篇浅谈C#手机号换成111XXXX1111 这种显示的解决思路。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-25
  • js验证身份证号有效性并提示对应信息

    直接上代码,逐行对代码进行研究,一定会有所收获。function nunber(allowancePersonValue){ if(allowancePersonValue=="身份证号"){ $("#span_username").show(); $("#span_username").html("身份证号不能为空"); r...2015-10-21
  • 浅谈js正则之test方法bug篇

    其实我很少用这个,所以之前一直没注意这个问题,自从落叶那厮写了个变态的测试我才去看了下这东西...2021-05-07
  • C#实现验证身份证是否合法的方法

    这篇文章主要介绍了C#实现验证身份证是否合法的方法,实例分析了通过自定义函数实现针对身份证合法性验证的技巧,非常具有实用价值,需要的朋友可以参考下...2020-06-25
  • JS利用正则配合replace替换指定字符

    替换指定字符的方法有很多,在本文为大家详细介绍下,JS利用正则配合replace是如何做到的,喜欢的朋友可以参考下...2021-05-07
  • Spring-AOP 静态正则表达式方法如何匹配切面

    这篇文章主要介绍了Spring-AOP 静态正则表达式方法如何匹配切面的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-07-19
  • php正则中文表达式

    php教程正则中文表达式 $str = "abc一二三cde"; echo preg_replace('/[^x4e00-x9fa5]/i'," ",$str); $str = "php编程"; if (preg_match("/^[x4e00-x9fa5]+$/u",$s...2016-11-25
  • php正则入门 实习email和URL验证

    匹配email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)* 匹配网址url的正则表达式:[a-za-z]+://[^s]* 下面看一实例 <body onload="f.a.select();"> <?php...2016-11-25
  • PHP正则判断输入是否字母实例程序

    在php中判断是否为纯字母我们可直接使用正则/^[a-zA-Z]$/来验证了,包括大小写字母哦,有需要了解的同学可参考参考。 上代码 代码如下 复制代码 ...2016-11-25
  • C#正则检测字符串是否字母数字混编的方法

    这篇文章主要介绍了C#正则检测字符串是否字母数字混编的方法,涉及C#正则判定字符串的使用技巧,需要的朋友可以参考下...2020-06-25