«
学习PHP收集的几个有用函数

时间:2008-5-31    作者:Deri    分类: 分享


   <p>  很有用的一些函数,你可以作为源码保存,然后以后避免重复编写。</p><p>  文件读取函数</p><code>  //文件读取函数<br />  function PHP_Read($file_name) {<br />  $fd=fopen($file_name,r);<br />  while($bufline=fgets($fd, 4096)){<br />  $buf.=$bufline;<br />  }<br />  fclose($fd);<br />  return $buf;<br />  }<br />  ?></code><p>  文件写入函数</p><code>  //文件写入函数<br />  function PHP_Write($file_name,$data,$method="w") {<br />  $filenum=@fopen($file_name,$method);<br />  flock($filenum,LOCK_EX);<br />  $file_data=fwrite($filenum,$data);<br />  fclose($filenum);<br />  return $file_data;<br />  }<br />  ?></code><p>  静态页面生成函数</p><code>  //静态页面生成函数<br />  function phptohtm($filefrom,$fileto,$u2u=1){<br />  if($u2u==1){<br />  $data=PHP_Read($filefrom);<br />  }else{<br />  $data=$filefrom;<br />  }<br />  PHP_Write($fileto,$data);<br />  return true;<br />  }<br />  ?></code><p>  指定条件信息数量检索函数</p><code>  //指定条件信息数量检索函数<br />  function rec_exist($table,$where){<br />  $query="select count(*) as num from $table ".$where;<br />  $result=mysql_query($query) or die(nerror(1));<br />  $rowcount=mysql_fetch_array($result);<br />  $num=$rowcount["num"];<br />  if ($num==0){<br />  return false;<br />  }<br />  return $num;<br />  }<br />  ?></code><p>  目录删除函数</p><code>  //目录删除函数<br />  function del_DIR($directory){<br />  $mydir=dir($directory);<br />  while($file=$mydir->read()){<br />  if((is_dir("$directory/$file")) AND ($file!=".") AND ($file!="..")){<br />  del_DIR("$directory/$file");<br />  }else{<br />  if(($file!=".") AND ($file!="..")){<br />  unlink("$directory/$file");<br />  //echo "unlink $directory/$file ok ";<br />  }<br />  }<br />  }<br />  $mydir->close();<br />  rmdir($directory);<br />  //echo "rmdir $directory ok ";<br />  }<br />  ?></code><p>  目录名称合法性检测函数</p>
<p> </p>

   <code>  //目录名称合法性检测<br />  function isen($str){<br />  $ret="";<br />  for($i=0;$i  $p=ord(substr($str,$i,1));<br />  if(($p<48 & $p!=45 & $p!=46) || ($p>57 & $p<65) || ($p>90 & $p<97 & $p!=95) || $p>122){<br />  nerror("不符合规范!");<br />  }<br />  $ret.=chr($p);<br />  }<br />  return $ret;<br />  }<br />  ?></code><p>  分页函数</p><code>  //分页函数<br />  function splitlist($HALT,$LRLIST,$ECHOCNT,$paper,$table,$where,$page_id,$userid){<br />  global $splitstr,$sumcnt;<br />  if($paper=="" || $sumcnt==""){<br />  $query = "select count(*) as num from $table $where";<br />  $result = mysql_query($query);<br />  $row = mysql_fetch_array($result);<br />  $sumcnt=$row["num"];<br />  if($sumcnt==0){<br />  nerror("该版内还没有选择发布新闻 !");<br />  }<br />  $paper=1;<br />  }<br />  $sumpaper=($sumcnt-$sumcnt%$ECHOCNT)/$ECHOCNT;<br />  if(($sumcnt%$ECHOCNT)!=0) $sumpaper+=1;<br />  if($sumpaper==1 && $HALT==0) return($where);<br />  $enwhere=base64_encode(base64_encode($where));<br />  if(($LRLIST*2+1) < $sumpaper){<br />  if(($paper-$LRLIST) < 2){<br />  $tract=1;<br />  $sub=$LRLIST*2+1;<br />  }else if(($paper+$LRLIST) >= $sumpaper){<br />  $tract=$sumpaper-($LRLIST*2);<br />  $sub=$sumpaper;<br />  }else{<br />  $tract=$paper-$LRLIST;<br />  $sub=$paper+$LRLIST;<br />  }<br />  }else{<br />  $tract=1;<br />  $sub=$sumpaper;<br />  }<br />  $uppaper=$paper-1;<br />  $downpaper=$paper+1;<br />  $startcnt=($paper-1)*$ECHOCNT;<br />  $where.=" limit ${ startcnt },${ ECHOCNT }";<br />  if($tract > 1) { $splitstr="【 << "; }<br />  else $splitstr="【 << ";<br />  for($i=$tract;$i<=$sub;$i++){<br />  if ($i!=$paper) $splitstr.="".$i." ";<br />  else $splitstr.="".$i." ";<br />  }<br />  if ($sub!=$sumpaper) $splitstr.=">> 】";<br />  else $splitstr.=">> 】";<br />  return($where);<br />  }<br />  ?></code><p>  关于分页函数的使用说明 </p>
 <p> </p>

   <code>  /*<br />  #### 检索分页函数 ####<br />  Int $HALT - 检索结果仅分1页时是否(1/0)显示页码条<br />  Int $LRLIST - (页码条显示页码数-1)/2<br />  Int $ECHOCNT - 检索时每页显示记录的数量<br />  Int $paper - 页数,预提取:$paper=$HTTP_GET_VARS[paper];<br />  Varchar $table - 数据表名,预附值:$table="db.table";<br />  Varchar $where - 检索条件,预附值:$where="where field='value'";<br />  Varchar $enwhere - 将原$where进行两次base64_encode()编码后以GET的方式提交<br />  Varchar $splitstr - 页码条输出字串,执行函数后在相应的位置执行 echo $splitstr;<br />  函数调用前需获取变量 -<br />  $paper=$HTTP_GET_VARS[paper];<br />  $sumcnt=$HTTP_GET_VARS[sumcnt];<br />  $enwhere=$HTTP_GET_VARS[enwhere];<br />  Return (Varchar $where) - 分页后检索语句的检索条件<br />  注意:本函数需调用出错处理函数 nerror($error);<br />  */<br />  ?></code><p>  图片文件上传函数</p><code>  //图片文件上传函数<br />  function upload_img($UploadFile,$UploadFile_name,$UploadFile_size,$UploadPath,$max_size=64){<br />  //$TimeLimit=60; //设置超时限制时间 缺省时间为 30秒 设置为0时为不限时<br />  //set_time_limit($TimeLimit);<br />  if(($UploadFile!= "none" )&&($UploadFile != "" )){<br />  $FileName=$UploadPath.$UploadFile_name;<br />  if($UploadFile_size <1024){<br />  $FileSize="(string)$UploadFile_size" . "字节";<br />  }elseif($UploadFile_size <(1024 * $max_size)){<br />  $FileSize=number_format((double)($UploadFile_size / 1024), 1) . " KB";<br />  }else{<br />  nerror("文件超过限制大小!");<br />  }<br />  //{<br />  //$FileSize="number_format((double)($UploadFile_size" / (1024 * 1024)), 1) . " MB";<br />  // }<br />  if(!file_exists($FileName)){<br />  if(copy($UploadFile,$FileName)){<br />  return "$UploadFile_name ($FileSize)";<br />  }else{<br />  nerror("文件 $UploadFile_name 上载失败!");<br />  }<br />  unlink($UploadFile);<br />  }else{<br />  nerror("文件 $UploadFile_name 已经存在!");<br />  }<br />  //set_time_limit(30); //恢复缺省超时设置<br />  }<br />  }<br />  ?></code></p>