文件读取函式
// 文件读取函式
ฟังก์ชั่น PHP_Read($file_name) {
$fd=fopen($file_name,r);
ในขณะที่($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){
ถ้า($u2u==1){
$data=PHP_Read($filefrom);
}อื่น{
$data=$ไฟล์จาก;
-
PHP_Write($ไฟล์,$data);
กลับเป็นจริง;
-
?>
指定条件信息数量检索函式
//指定条件信息数量检索函式
ฟังก์ชั่น rec_exist($table,$where){
$query="select count(*) เป็น num จาก $table ".$where;
$result=mysql_query($query) หรือ die(nerror(1));
$rowcount=mysql_fetch_array($ผลลัพธ์);
$num=$rowcount["num"];
ถ้า ($num==0){
กลับเท็จ;
-
ส่งคืน $num;
-
?>
目录删除函式
//目录删除函式
ฟังก์ชั่น del_DIR($ไดเร็กทอรี){
$mydir=dir($ไดเรกทอรี);
ในขณะที่($file=$mydir->อ่าน()){
if((is_dir("$directory/$file")) AND ($file!=".") AND ($file!="..")){
del_DIR("$ไดเรกทอรี/$ไฟล์");
}อื่น{
if(($file!=".") และ ($file!="..")){
ยกเลิกการเชื่อมโยง("$directory/$file");
//echo "ยกเลิกการเชื่อมโยง $directory/$file ok";
-
-
-
$mydir->ปิด();
rmdir($ไดเรกทอรี);
//echo "rmdir $directory ตกลง";
-
?>
目录名称合法性检测函式
//目录名称合法性检测
ฟังก์ชั่น isen($str){
$ret="";
สำหรับ($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;
ถ้า($กระดาษ=="" || $sumcnt==""){
$query = "เลือกจำนวน(*) เป็นตัวเลขจาก $table $where";
$result = mysql_query($query);
$row = mysql_fetch_array($ผลลัพธ์);
$sumcnt=$row["num"];
ถ้า($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){
ถ้า(($กระดาษ-$LRLIST) < 2){
$ทางเดิน=1;
$sub=$LRLIST*2+1;
}else if(($กระดาษ+$LRLIST) >= $sumpaper){
$tract=$sumpaper-($LRLIST*2);
$sub=$sumpaper;
}อื่น{
$tract=$กระดาษ-$LRLIST;
$sub=$กระดาษ+$LRLIST;
-
}อื่น{
$ทางเดิน=1;
$sub=$sumpaper;
-
$uppaper=$กระดาษ-1;
$downpaper=$กระดาษ+1;
$startcnt=($paper-1)*$ECHOCNT;
$where.=" จำกัด ${ startcnt },${ ECHOCNT }";
ถ้า($tract > 1) { $splitstr="【 << "; -
อย่างอื่น $splitstr="【 << ";
สำหรับ($i=$tract;$i<=$sub;$i++){
ถ้า ($i!=$paper) $splitstr.="".$i" ";
อย่างอื่น $splitstr.="".$i" ";
-
ถ้า ($sub!=$sumpaper) $splitstr.=">> ]";
อย่างอื่น $splitstr.=">> ]";
กลับ($ที่ไหน);
-
?>
关于分页函式的使用说明
-
#### 检索分页函式 ####
Int $HALT - 检索结果仅分1页时是否(1/0)显示页码条
Int $LRLIST - (页码条显示页码数-1)/2
Int $ECHOCNT - 检索时每页显示记录的数量
Int $paper - 页数,预提取:$paper=$HTTP_GET_VARS[กระดาษ];
Varchar $table - 数据表名,预附值:$table="db.table";
Varchar $where - 检索条件,预附值:$where="where field='value'";
Varchar $enwhere - 将原$where进行两次base64_encode()编码后以GET的方式提交
Varchar $splitstr - 页码条输出字串,执行函式后在相应的位置执行 echo $splitstr;
函式调用前需获取变量 -
$กระดาษ=$HTTP_GET_VARS[กระดาษ];
$sumcnt=$HTTP_GET_VARS[ผลรวม];
$enwhere=$HTTP_GET_VARS[enwhere];
กลับ (Varchar $where) - 分页后检索语句的检索条件
注意:本函式需调用出错处理函式 nerror($error);
-
上文件上传函式
//上文件上传函式
ฟังก์ชั่น upload_img($UploadFile,$UploadFile_name,$UploadFile_size,$UploadPath,$max_size=64){
//$จำกัดเวลา=60; //设置超时限制时间 缺省时间为 30秒 设置为0时为不限时
//set_time_limit($จำกัดเวลา);
if(($UploadFile!= "none" )&&($UploadFile != "" )){
$FileName=$UploadPath.$UploadFile_name;
ถ้า($UploadFile_size <1024){
$FileSize="(string)$UploadFile_size" . "字节";
}elseif($UploadFile_size <(1024 * $max_size)){
$FileSize=number_format((double)($UploadFile_size / 1024), 1) . " เคบี";
}อื่น{
nerror("文件超过限制ตัวใหญ่!");
-
-
//$FileSize="number_format((double)($UploadFile_size" / (1024 * 1024)), 1) . " เอ็มบี";
-
ถ้า(!file_exists($ชื่อไฟล์)){
ถ้า(คัดลอก($อัพโหลดไฟล์,$ชื่อไฟล์)){
กลับ "$UploadFile_name ($FileSize)";
}อื่น{
nerror("文件 $UploadFile_name 上载失败!");
-
ยกเลิกการเชื่อมโยง($อัพโหลดไฟล์);
}อื่น{
nerror("文件 $UploadFile_name 已经存在!");
-
//set_time_limit(30); //恢复缺省超时设置
-
-
-------------------------------------------------- -------------------------------------------------- -----------------------------------
以下是一些小技巧:
-------------------------------------------------- -------------------------------------------------- ----------------------------------
如何判断ip地址合法性
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地址和mask是否合法的例子
$ไอพี = '192.168.0.84';
$มาสก์ = '255.255.255.0';
$เครือข่าย = '192.168.0';
$ip = ip2long($ip);
$mask = ip2long($mask);
$เครือข่าย = ip2long($เครือข่าย);
if( ($ip & $mask) == $network) echo "ip และ maskn ที่ถูกต้อง";
-
----
文件下载头部输出如何设定
header("ประเภทเนื้อหา: application/x-download");
header("การจัดการเนื้อหา: ไฟล์แนบ; filename=$file_download_name;");
ส่วนหัว ("ยอมรับช่วง: ไบต์");
header("ความยาวเนื้อหา: $download_size");
echo 'xxx'
用header输出ftp下载方式,并且支持断点续传一个例子:
ส่วนหัว ('Pragma: สาธารณะ');
ส่วนหัว ('การควบคุมแคช: ส่วนตัว');
header('การควบคุมแคช: ไม่มีแคช, ต้องตรวจสอบใหม่');
header('ยอมรับช่วง: ไบต์');
header('การเชื่อมต่อ: ปิด');
header("ประเภทเนื้อหา: เสียง/mpeg");
header("Location:ftp://download:[email protected]/2222/web技术เปิด发知识库/cn_web.rmvb");
正则匹配中文
ereg("^[".chr(0xa1)."-".chr(0xff)."]+$", $str); เข้าสู่
ระบบ
<?php
ฟังก์ชั่น urlParse($str = ''){
ถ้า ('' == $str) ให้ส่งคืน $str;
$types = array("http", "ftp", "https");
$แทนที่ = <<<EOHPP
'<a href="'.htmlentities('1').htmlentities('2').'">'.htmlentities('1').htmlentities('2').'</a> '
อีโอพีพี;
$ret = $str;
ในขณะที่(รายการ(,$ประเภท) = แต่ละ($ประเภท)){
$ret = preg_replace("|($type://)([^s]*)|ie ", $replace, $ret);
}
ส่งคืน $ret;
-
-