文件读取函式
//文件读取函式
함수 PHP_Read($file_name) {
$fd=fopen($file_name,r);
while($bufline=fgets($fd, 4096)){
$buf.=$bufline;
}
fclose($fd);
$buf를 반환합니다.
}
?>
文件写入函式
//文件写入函式
함수 PHP_Write($file_name,$data,$method="w") {
$filenum=@fopen($file_name,$method );
무리($filenum,LOCK_EX);
$file_data=fwrite($filenum,$data);
fclose($파일번호);
$file_data를 반환합니다.
}
?>
静态页面生成函式
//静态页면생성函式
함수 phptohtm($filefrom,$fileto,$u2u=1){
if($u2u==1){
$data=PHP_Read($filefrom);
}또 다른{
$data=$filefrom;
}
PHP_Write($fileto,$data);
사실을 반환;
}
?>
정해진 수량 检索函式
//정적 수량 갯수
함수 rec_exist($table,$where){
$query="$table ".$where에서 숫자로 count(*)를 선택합니다.
$result=mysql_query($query) 또는 die(nerror(1));
$rowcount=mysql_fetch_array($result);
$num=$rowcount["num"];
if ($num==0){
거짓을 반환;
}
$num을 반환합니다.
}
?>
目录删除函式
//目录删除函式
함수 del_DIR($directory){
$mydir=dir($디렉터리);
while($file=$mydir->읽기()){
if((is_dir("$directory/$file")) AND ($file!=".") AND ($file!="..")){
del_DIR("$디렉터리/$file");
}또 다른{
if(($file!=".") AND ($file!="..")){
unlink("$디렉터리/$file");
//echo "$directory/$file 링크 해제 ok ";
}
}
}
$mydir->닫기();
rmdir($디렉터리);
//echo "rmdir $directory ok";
}
?>
目录name称합법성检测函式
//目录name称합법성检测
함수 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를 반환합니다;
}
?>
분할
//分页函式
함수 분할 목록($HALT,$LRLIST,$ECHOCNT,$paper,$table,$where,$page_id,$userid){
전역 $splitstr,$sumcnt;
if($paper=="" || $sumcnt==""){
$query = "$table $where에서 숫자로 count(*)를 선택합니다";
$결과 = mysql_query($query);
$row = mysql_fetch_array($result);
$sumcnt=$row["num"];
if($sumcnt==0){
nerror("该版内还没有选择发布new闻!");
}
$종이=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){
$트랙=1;
$sub=$LRLIST*2+1;
}else if(($paper+$LRLIST) >= $sumpaper){
$tract=$sumpaper-($LRLIST*2);
$sub=$sumpaper;
}또 다른{
$tract=$paper-$LRLIST;
$sub=$paper+$LRLIST;
}
}또 다른{
$트랙=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 - 检索时每页显示记录的数weight
Int $paper - 页数,预提取:$paper=$HTTP_GET_VARS[paper];
Varchar $table - 数据表name,预附值:$table="db.table";
Varchar $where - 检索条件,预附值:$where="where field='value'";
Varchar $enwhere - 将원$where进行两次base64_encode()编码后以GET 的方式提交
Varchar $splitstr - 에코 $splitstr;
函式调사용前需获取变weight -
$paper=$HTTP_GET_VARS[종이];
$sumcnt=$HTTP_GET_VARS[sumcnt];
$enwhere=$HTTP_GET_VARS[enwhere];
반환(Varchar $where) - 分页后检索语句的检索条件
참고: 本函式需调사용 出错处理函式 nerror($error);
*/
图文文件上传函式
//图文文件上传函式
함수 upload_img($UploadFile,$UploadFile_name,$UploadFile_size,$UploadPath,$max_size=64){
//$TimeLimit=60; //设置超时限 제조사 时间 缺省时间为 30秒 设置为0时为不限时
//set_time_limit($TimeLimit);
if(($UploadFile!= "없음" )&&($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(복사($UploadFile,$FileName)){
"$UploadFile_name($FileSize)"를 반환합니다.
}또 다른{
nerror("文件 $UploadFile_name 上载失败!");
}
링크 해제($UploadFile);
}또 다른{
nerror("文件 $UploadFile_name 已经存재!");
}
//set_time_limit(30); //恢复缺省超时设置
}
}
------------------------------------- -----------------
以下是一些작은技巧:
------------------------------------- -----------------
如何判断ip지질합법성
if(!strcmp(long2ip(sprintf("%u",ip2long($ip))),$ip)) echo "ipn입니다";
----
이메일을 보내세요
eregi("^[_.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';
$네트워크 = '192.168.0';
$ip = ip2long($ip);
$mask = ip2long($mask);
$네트워크 = ip2long($네트워크);
if( ($ip & $mask) == $network) echo "유효한 IP 및 마스크n";
?>
----
文件下载头输如何何设정
header("콘텐츠 유형: 애플리케이션/x-download");
header("콘텐츠 처리: 첨부 파일; 파일 이름=$file_download_name;");
header("수락 범위: 바이트");
header("콘텐츠 길이: $download_size");
echo 'xxx'
사용 헤더를 ftp 下载方式,并且支持断点续传一个例子:
header('프라그마: 공개');
header('캐시 제어: 비공개');
header('캐시 제어: 캐시 없음, 재검증 필수');
header('Accept-Ranges: 바이트');
header('연결: 닫기');
header("콘텐츠 유형: 오디오/mpeg");
header("위치:ftp://download:[email protected]/2222/web技术开发知识库/cn_web.rmvb");
正则匹配中文
"
.chr(0xff)."]+$", $str);
<?php
함수 urlParse($str = ''){
if ('' == $str) return $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) = 각각($types)){
$ret = preg_replace("|($type://)([^s]*)|ie ", $replace, $ret);
}
$ret를 반환합니다;
}
?>