一些php常用正则表达式收集
“^/d+$” //非负整数(正整数 + 0)
“^[0-9]*[1-9][0-9]*$” //正整数
“^((-/d+)|(0+))$” //非正整数(负整数 + 0)
“^-[0-9]*[1-9][0-9]*$” //负整数
“^-?/d+$” //整数
“^/d+(/./d+)?$” //非负浮点数(正浮点数 + 0)
“^(([0-9]+/.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*/.[0-9]+)|([0-9]*[1-9][0-9]*))$” //正浮点数
“^((-/d+(/./d+)?)|(0+(/.0+)?))$” //非正浮点数(负浮点数 + 0)
“^(-(([0-9]+/.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*/.[0-9]+)|([0-9]*[1-9][0-9]*)))$” //负浮点数
“^(-?/d+)(/./d+)?$” //浮点数
“^[A-Za-z]+$” //由26个英文字母组成的字符串
“^[A-Z]+$” //由26个英文字母的大写组成的字符串
“^[a-z]+$” //由26个英文字母的小写组成的字符串
“^[A-Za-z0-9]+$” //由数字和26个英文字母组成的字符串
“^/w+$” //由数字、26个英文字母或者下划线组成的字符串
“^[/w-]+(/.[/w-]+)*@[/w-]+(/.[/w-]+)+$” //email地址
“^[a-zA-z]+://(/w+(-/w+)*)(/.(/w+(-/w+)*))*(/?/S*)?$” //url
/^(d{2}|d{4})-((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0|1]))$/ // 年-月-日
/^((0([1-9]{1}))|(1[1|2]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$/ // 月/日/年
“^([w-.]+)@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([w-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$” //Emil
“(d+-)?(d{4}-?d{7}|d{3}-?d{8}|^d{7,8})(-d+)?” //电话号码
“^(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5])$” //IP地址
匹配中文字符的正则表达式: [/u4e00-/u9fa5]
匹配双字节字符(包括汉字在内):[^/x00-/xff]
匹配空行的正则表达式:/n[/s| ]*/r
匹配HTML标记的正则表达式:/<(.*)>.*<///1>|<(.*) //>/
匹配首尾空格的正则表达式:(^/s*)|(/s*$)
匹配Email地址的正则表达式:/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*
匹配网址URL的正则表达式:^[a-zA-z]+://(//w+(-//w+)*)(//.(//w+(-//w+)*))*(//?//S*)?$
匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
匹配国内电话号码:(/d{3}-|/d{4}-)?(/d{8}|/d{7})?
匹配腾讯QQ号:^[1-9]*[1-9][0-9]*$
⊕本文来自: 北海情书 (php0.net">www.php0.net) 详细出处参考:http://www.php0.net/?p=827
PHP文件读取函式
//文件读取函式
代码如下 | 复制代码 |
function PHP_Read($file_name) { $fd=fopen($file_name,r); while($bufline=fgets($fd, 4096)){ $buf.=$bufline; } fclose($fd); return $buf; } ?> |
文件写入函式
//文件写入函式
代码如下 | 复制代码 |
function PHP_Write($file_name,$data,$method=”w”) { $filenum=@fopen($file_name,$method); flock($filenum,LOCK_EX); $file_data=fwrite($filenum,$data); fclose($filenum); return $file_data; } ?> |
静态页面生成函式
//静态页面生成函式
代码如下 | 复制代码 |
function phptohtm($filefrom,$fileto,$u2u=1){ if($u2u==1){ $data=PHP_Read($filefrom); }else{ $data=$filefrom; } PHP_Write($fileto,$data); return true; } ?> |
指定条件信息数量检索函式
//指定条件信息数量检索函式
代码如下 | 复制代码 |
function rec_exist($table,$where){ $query=”select count(*) as num from $table “.$where; $result=mysql_query($query) or die(nerror(1)); $rowcount=mysql_fetch_array($result); $num=$rowcount["num"]; if ($num==0){ return false; } return $num; } ?> |
目录删除函式
//目录删除函式
代码如下 | 复制代码 |
function del_DIR($directory){ $mydir=dir($directory); while($file=$mydir->read()){ if((is_dir(“$directory/$file”)) AND ($file!=”.”) AND ($file!=”..”)){ del_DIR(“$directory/$file”); }else{ if(($file!=”.”) AND ($file!=”..”)){ unlink(“$directory/$file”); //echo “unlink $directory/$file ok “; } } } $mydir->close(); rmdir($directory); //echo “rmdir $directory ok “; } ?> |
目录名称合法性检测函式
//目录名称合法性检测
代码如下 | 复制代码 |
function isen($str){ $ret=”"; for($i=0;$i $p=ord(substr($str,$i,1)); if(($p<48 & $p!=45 & $p!=46) || ($p>57 & $p<65) || ($p>90 & $p<97 & $p!=95) || $p>122){ nerror(“不符合规范!”); } $ret.=chr($p); } return $ret; } ?> |
PHP分页函数
代码如下 | 复制代码 |
//分页函数 function splitlist($HALT,$LRLIST,$ECHOCNT,$paper,$table,$where,$page_id,$userid){ global $splitstr,$sumcnt; if($paper==”" || $sumcnt==”"){ $query = “select count(*) as num from $table $where”; $result = mysql_query($query); $row = mysql_fetch_array($result); $sumcnt=$row["num"]; if($sumcnt==0){ nerror(“该版内还没有选择发布新闻 !”); } $paper=1; } $sumpaper=($sumcnt-$sumcnt%$ECHOCNT)/$ECHOCNT; if(($sumcnt%$ECHOCNT)!=0) $sumpaper+=1; if($sumpaper==1 && $HALT==0) return($where); $enwhere=base64_encode(base64_encode($where)); if(($LRLIST*2+1) < $sumpaper){ if(($paper-$LRLIST) < 2){ $tract=1; $sub=$LRLIST*2+1; }else if(($paper+$LRLIST) >= $sumpaper){ $tract=$sumpaper-($LRLIST*2); $sub=$sumpaper; }else{ $tract=$paper-$LRLIST; $sub=$paper+$LRLIST; } }else{ $tract=1; $sub=$sumpaper; } $uppaper=$paper-1; $downpaper=$paper+1; $startcnt=($paper-1)*$ECHOCNT; $where.=” limit ${ startcnt },${ ECHOCNT }”; if($tract > 1) { $splitstr=”【 << “; } else $splitstr=”【 << “; for($i=$tract;$i<=$sub;$i++){ if ($i!=$paper) $splitstr.=”".$i.” “; else $splitstr.=”".$i.” “; } if ($sub!=$sumpaper) $splitstr.=”>> 】”; else $splitstr.=”>> 】”; return($where); } ?> |
PHP关于分页函式的使用说明
PHP图片文件上传函式
//图片文件上传函式
代码如下 | 复制代码 |
function upload_img($UploadFile,$UploadFile_name,$UploadFile_size,$UploadPath,$max_size=64){ //$TimeLimit=60; //设置超时限制时间 缺省时间为 30秒 设置为0时为不限时 //set_time_limit($TimeLimit); if(($UploadFile!= “none” )&&($UploadFile != “” )){ $FileName=$UploadPath.$UploadFile_name; if($UploadFile_size <1024){ $FileSize=”(string)$UploadFile_size” . “字节”; }elseif($UploadFile_size <(1024 * $max_size)){ $FileSize=number_format((double)($UploadFile_size / 1024), 1) . ” KB”; }else{ nerror(“文件超过限制大小!”); } //{ //$FileSize=”number_format((double)($UploadFile_size” / (1024 * 1024)), 1) . ” MB”; // } if(!file_exists($FileName)){ if(copy($UploadFile,$FileName)){ return “$UploadFile_name ($FileSize)”; }else{ nerror(“文件 $UploadFile_name 上载失败!”); } unlink($UploadFile); }else{ nerror(“文件 $UploadFile_name 已经存在!”); } //set_time_limit(30); //恢复缺省超时设置 } } |
以下是一些小技巧:
PHP如何判断ip地址合法性
代码如下 | 复制代码 |
if(!strcmp(long2ip(sprintf(“%u”,ip2long($ip))),$ip)) echo “is ipn”; |
—-
email的正则判断
代码如下 | 复制代码 |
eregi(“^[_.0-9a-zA-Z-]+@([0-9a-zA-Z][0-9a-zA-Z_-]+.)+[a-zA-Z]$”, $email); |
检测ip地址和mask是否合法的例子
代码如下 | 复制代码 |
$ip = ’192.168.0.84′; $mask = ’255.255.255.0′; $network = ’192.168.0′; $ip = ip2long($ip); $mask = ip2long($mask); $network = ip2long($network); if( ($ip & $mask) == $network) echo “valid ip and maskn”; ?> |
—-
PHP文件下载头部输出如何设定
代码如下 | 复制代码 |
header(“Content-type: application/x-download”); header(“Content-Disposition: attachment; filename=$file_download_name;”); header(“Accept-Ranges: bytes”); header(“Content-Length: $download_size”); echo ‘xxx’ PHP用header输出ftp下载方式,并且支持断点续传 一个例子: header(‘Pragma: public’); header(‘Cache-Control: private’); header(‘Cache-Control: no-cache, must-revalidate’); header(‘Accept-Ranges: bytes’); header(‘Connection: close’); header(“Content-Type: audio/mpeg”); header(“Location:ftp://download:1bk3l4s3k9s2@232.2.22.22/2222/web技术开发知识库/cn_web.rmvb”); PHP正则匹配中文 ereg(“^[".chr(0xa1)."-".chr(0xff)."]+$”, $str); 批量替换文本里面的超级链接 function urlParse($str = ”){ if (” == $str) return $str; $types = array(“http”, “ftp”, “https”); $replace = << ”.htmlentities(’1′).htmlentities(’2′).” EOPHP; $ret = $str; while(list(,$type) = each($types)){ $ret = preg_replace(“|($type://)([^s]*)|ie “, $replace, $ret); } return $ret; } |
代码如下 | 复制代码 |
/** * CURL请求 * @param String $url 请求地址 * @param Array $data 请求数据 */ function curlRequest($url,$data='',$cookieFile=''){ $ch = curl_init(); $option = array( CURLOPT_URL => $url, CURLOPT_HEADER =>0, CURLOPT_RETURNTRANSFER => 1, ); if($cookieFile){ $option[CURLOPT_COOKIEJAR] = $cookieFile; $option[CURLOPT_COOKIEFILE] = $cookieFile; //$option[CURLOPT_COOKIESESSION] = true; //$option[CURLOPT_COOKIE] = 'prov=42;city=1'; } if($data){ $option[CURLOPT_POST] = 1; $option[CURLOPT_POSTFIELDS] = $data; } curl_setopt_array($ch,$option); $response = curl_exec($ch); if(curl_errno($ch) > 0){ throw_exception("CURL ERROR:$url ".curl_error($ch)); } curl_close($ch); return $response; } function login($username,$password){ if($username && $password){ $preLoginData = curlRequest('http://login.sina.com.cn/sso/prelogin.php?entry=weibo&callback=sinaSSOController.preloginCallBack&su='.base64_encode($username).'&client=ssologin.js(v1.3.16)','',self::COOKIE_FILE); preg_match('/sinaSSOController.preloginCallBack((.*))/',$preLoginData,$preArr); $jsonArr = json_decode($preArr[1],true); if(is_array($jsonArr)){ $postArr = array( 'entry' => 'weibo', 'gateway' => 1, 'from' => '', 'savestate' => 7, 'useticket' => 1, 'ssosimplelogin' => 1, 'su' => base64_encode(urlencode($username)), 'service' => 'miniblog', 'servertime' => $jsonArr['servertime'], 'nonce' => $jsonArr['nonce'], 'pwencode' => 'wsse', 'sp' => sha1(sha1(sha1($password)).$jsonArr['servertime'].$jsonArr['nonce']), 'encoding' => 'UTF-8', 'url' => 'http://weibo.com/ajaxlogin.php?framelogin=1&callback=parent.sinaSSOController.feedBackUrlCallBack', 'returntype' => 'META' ); $loginData = curlRequest('http://login.sina.com.cn/sso/login.php?client=ssologin.js(v1.3.16)',$postArr,self::COOKIE_FILE); if($loginData){ $matchs = array(); preg_match('/replace('(.*?)')/',$loginData,$matchs); $loginResult = curlRequest($matchs[1],'',self::COOKIE_FILE); $loginResultArr = array(); preg_match('/feedBackUrlCallBack((.*?))/',$loginResult,$loginResultArr); //$userInfo = json_decode($loginResultArr[1],true); //Log::info(var_export($loginResultArr[1])); }else{ throw_exception('Login sina fail.'); } }else{ throw_exception($preLoginData); } }else{ throw_exception('Param error.'); } } |
代码如下 | 复制代码 |
$URL='http://pp.baidu.com/';//任意网址 get_pic($URL); function get_pic($pic_url) { echo "<br>finished!!!"; /*得到图片类型,并将其保存到与该文件同一目录*/ foreach($pic_arr as $pic_item){//循环取出每幅图的地址 //通过微秒时间获得唯一ID //抓取网页内容 //curl_setopt($curl, CURLOPT_REFERER,$url); |
代码如下 | 复制代码 |
if (preg_match_all("/http://[^ "']+[.jpg|.gif|.jpeg|.png]+/ui",stripcslashes($content),$aliurl)){ $i=0; //多个文件++ while(list($key ,$v) = each($aliurl[0])){ //echo $v."<br />"; $filetype = pathinfo($v, PATHINFO_EXTENSION); //获取后缀名 $ff = @file_get_contents($v); //获取2进制文件内容 if(!stripos($v,"lao8.org")){//判断是否是自己网站下的图片 if (!empty($ff)){ //获取到文件就执行下面的操作 $dir = "upload/".date("Ymd")."/";//指定新的存储路径 if (!file_exists($dir)){//判断目录是否存在 @mkdir($dir,511,true); //创建多级目录,511转换成十进制是777具有可执行权限 } $nfn = $dir.date("Ymdhis").$i.".".$filetype; //构建文件的新名字 $nf = @fopen($nfn,"w"); //创建文件 fwrite($nf,$ff); //写入文件 fclose($nf); //关闭文件 $i++; //多文件++ echo "<img src="".$nfn."">"; $content = str_replace($v,$nfn, $content);//替换content中的参数 }else{//获取不到图片则替换为默认图片 $content = str_replace($v,http://www.111cn.net/banner/banner.gif, $content);//替换content中的参数 } } } } |
相关文章
- 取双引号内的内容我们如果一个字符串中只有一个可以使用explode来获得,但如果有多个需要使用正则表达式来提取了,具体的例子如下。 写程序的时候总结一点经验,如何只...2016-11-25
- 这篇文章主要给大家介绍了一个关于JS正则匹配的踩坑记录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-04-13
- 今天遇到一个正则匹配的问题,忽然翻到有捕获组的概念,手册上也是一略而过,百度时无意翻到C#和Java中有对正则捕获组的特殊用法,搜索关键词有PHP时竟然没有相关内容,自己试了一下,发现在PHP中也是可行的,于是总结一下,分享的同...2015-11-08
- 正则表达式是一门非常有用的并且进行模糊判断的一个功能了,我们下面来看通过正则来验证输入汉字、英语、数字,具体如下。 收藏了正则表达式。可以验证只能输入数...2016-11-25
- 这篇文章主要介绍了java正则表达式判断前端参数修改表中另一个字段的值,需要的朋友可以参考下...2021-05-07
- 常用的日期时间正则表达式 下面收藏了大量的日期时间正则匹配函数,包括分钟,时间与秒都能达到。 正则表达式 (?n:^(?=d)((?<day>31(?!(.0?[2469]|11))|30(?!.0?2)|29(...2016-11-25
- 网址规则是可寻的,所以我们可以使用正则表达式来提取字符串中的url地址了,下面一起来看看小编整理的几个PHP正则表达式匹配验证提取网址URL实例. 匹配网址 URL 的...2016-11-25
- 这篇文章主要介绍了正则表达式中两个反斜杠的匹配规则,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-05-07
- 这篇文章给大家详细介绍了JS中使用正则表达式g模式和非g模式的区别,非常不错,具有参考借鉴价值,需要的朋友参考下吧...2017-04-03
- 本文主要介绍了JavaScript利用正则表达式替换字符串中内容的具体实现方法,并做了简要注释,便于理解。具有一定的参考价值,需要的朋友可以看下...2017-01-09
- 这篇文章主要介绍了C#正则表达式使用方法,大家参考使用...2020-06-25
- c#正则表达式,用于字符串处理、表单验证等场合,实用高效。现将一些常用的表达式收集于此,以备不时之需。...2020-06-25
- 这篇文章主要介绍了python正则表达式常用函数及使用方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-05-07
- 这篇文章给大家介绍了Idea使用正则表达式批量替换字符串的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧...2021-07-21
- 关于匹配字符串问题,有很多种类型,今天讨论 js 代码里的字符串匹配,因为我想学完之后写个语法高亮练手,所以用js代码当作例子...2021-05-07
- 今天遇到一个正则匹配的问题,忽然翻到有捕获组的概念,手册上也是一略而过,百度时无意翻到C#和Java中有对正则捕获组的特殊用法,搜索关键词有PHP时竟然没有相关内容,自己试了一下,发现在PHP中也是可行的,于是总结一下,分享的同...2015-11-08
- 正则表达式的作用用来描述字符串的特征。本文重点给大家介绍C# 中使用正则表达式匹配字符的含义,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧...2020-06-25
- 这篇文章主要给大家介绍了关于利用Python验证的50个常见正则表达式的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-11
- 这篇文章主要介绍了C#运算符和表达式,这是自学C#编程的第五篇,希望对大家的学习有所帮助。...2020-06-25
- 这篇文章主要介绍了PHP正则表达式过滤html标签属性的相关内容,实用性非常,感兴趣的朋友参考下吧...2016-05-06