文件读取関数式
//文件读取関数式
関数 PHP_Read($file_name) {
$fd=fopen($ファイル名,r);
while($bufline=fgets($fd, 4096)){
$buf.=$bufline;
}
fclose($fd);
$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);
$file_data を返します。
}
?>
静态页面生成関数式
//静态页面生成関数式
関数 phptohtm($filefrom,$fileto,$u2u=1){
if($u2u==1){
$data=PHP_Read($filefrom);
}それ以外{
$data=$filefrom;
}
PHP_Write($fileto,$data);
true を返します。
}
?>
指定
条件情報量検索関数式 // 指定条件情報量検索関数式
関数rec_exist($table,$where){
$query="select count(*) as num from $table ".$where;
$result=mysql_query($query) または die(nerror(1));
$rowcount=mysql_fetch_array($result);
$num=$rowcount["num"];
if ($num==0){
false を返します。
}
$num を返します。
}
?>
目录删除関数式
//目录删除関数式
関数 del_DIR($ディレクトリ){
$mydir=ディレクトリ($ディレクトリ);
while($file=$mydir->read()){
if((is_dir("$directory/$file")) AND ($file!=".") AND ($file!="..")){
del_DIR("$ディレクトリ/$ファイル");
}それ以外{
if(($file!=".") AND ($file!="..")){
unlink("$ディレクトリ/$ファイル");
//echo "$directory/$file のリンクを解除します。 ok ";
}
}
}
$mydir->close();
rmdir($ディレクトリ);
//エコー "rmdir $directory ok ";
}
?>
目录名合法性检测関数
//目录名称合法性检测
関数 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);
}
$ret を返します。
}
?>
分页関数式
//分页関数式
関数 splitlist($HALT,$LRLIST,$ECHOCNT,$paper,$table,$where,$page_id,$userid){
グローバル $splitstr,$sumcnt;
if($paper=="" || $sumcnt==""){
$query = "$table $where から num として count(*) を選択";
$result = mysql_query($query);
$row = mysql_fetch_array($result);
$sumcnt=$row["num"];
if($sumcnt==0){
nerror("该版内还没有选择発行新闻 !");
}
$ペーパー=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;
}それ以外{
$tract=$paper-$LRLIST;
$sub=$paper+$LRLIST;
}
}それ以外{
$tract=1;
$sub=$sumpaper;
}
$uppaper=$paper-1;
$downpaper=$paper+1;
$startcnt=($paper-1)*$ECHOCNT;
$where.=" 制限 ${ 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.=">> ]";
リターン($where);
}
?>
分関数式の使用説明について
/*
#### 检索分页関数式 ####
Int $HALT - 検索結果が 1 分ごとにあるかどうか (1/0) 表示コード条
Int $LRLIST - (页码条显表示页コード数-1)/2
Int $ECHOCNT - 検索時間の表示数
Int $paper - 页数,预提取:$paper=$HTTP_GET_VARS[paper];
Varchar $table - データベース表名,预附值:$table="db.table";
Varchar $where - 検索条件,预附值:$where="where field='value'";
Varchar $enwhere - 元の $where を 2 回実行して、base64_encode() コードを取得してから GET する方法
Varchar $splitstr - コード条出力文字列、関数式を実行した後、対応する位置で実行 echo $splitstr;
関数式调用前必要获取变量 -
$paper=$HTTP_GET_VARS[論文];
$sumcnt=$HTTP_GET_VARS[sumcnt];
$enwhere=$HTTP_GET_VARS[enwhere];
Return (Varchar $where) - 分後に句を検索する検索条件
注意:本関数式必要调用出错处処理関数式 nerror($error);
*/
画像ファイル上传関数式//画像ファイル上传関
数式
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」;
}それ以外{
nerror("文件超过制限大小!");
}
//{
//$FileSize="number_format((double)($UploadFile_size" / (1024 * 1024)), 1) 。 「MB」;
// }
if(!file_exists($FileName)){
if(copy($UploadFile,$FileName)){
"$UploadFile_name ($FileSize)" を返します。
}それ以外{
nerror("文件 $UploadFile_name 上ダウンロード失败!");
}
リンクを解除($UploadFile);
}それ以外{
nerror("文件 $UploadFile_name すでに存在します!");
}
//set_time_limit(30); //恢复缺省超時間設置
}
}
-------------------------------------------------- ----------------------------
以下は小技巧です:
-------------------------------------------------- ----------------------------
地址の合法性をどのように判断するか
if(!strcmp(long2ip(sprintf("%u",ip2long($ip))),$ip)) echo "は ipn";
----
メールの正当性判断
エレギ("^[_.0-9a-zA-Z-]+@([0-9a-zA-Z][0-9a-zA-Z_-]+.)+[a-zA-Z]$ ", $email);
检测ipアドレスとマスクが合法かどうかの例
$ip = '192.168.0.84';
$マスク = '255.255.255.0';
$network = '192.168.0';
$ip = ip2long($ip);
$mask = ip2long($mask);
$network = ip2long($network);
if( ($ip & $mask) == $network) echo "有効な IP とマスクn";
?>
----
文件下載头部输出方法设定
header("コンテンツタイプ: application/x-download");
header("Content-Disposition:attachment;filename=$file_download_name;");
header("Accept-Range: バイト");
header("Content-Length: $download_size");
echo 'xxx' は
ヘッダー出力 ftp ダウンロード方式であり、切断点の例をサポートします:
header('プラグマ: public');
header('キャッシュ制御: プライベート');
header('キャッシュ制御: キャッシュなし、再検証が必要');
header('Accept-Range: バイト');
header('接続: 閉じる');
header("Content-Type: audio/mpeg");
header("Location:ftp://download:[email protected]/2222/web技术开発行知识库/cn_web.rmvb");
正则適合中文
ereg("^[".chr(0xa1)."-".chr(0xff)."]+$", $str);
批量替换文本里面的超级链接
<?php
関数 urlParse($str = ''){
if ('' == $str) $str を返します。
$types = array("http", "ftp", "https");
$replace = <<<EOPHP
'<a href="'.htmlentities('1').htmlentities('2').'">'.htmlentities('1').htmlentities('2').'</a> '
EOPHP;
$ret = $str;
while(list(,$type) = each($types)){
$ret = preg_replace("|($type://)([^s]*)|ie ", $replace, $ret);
$ret を返します
。
}
?>