PHP 常用函数库和一些实用小技巧

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: PHP 常用函数库和一些实用小技巧 作者: 字体:[增加 减小] 类型:转载   包括文件读取函式,文件写入函式,静态页面生成函式,目录删除函式等   文件读取函式 //文件读取函式 function PHP_Read($file_name) { $fd=fopen($file_name,r); while($bufline=fgets($fd, 4096)){ $buf.

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; 

?> 
分页函式 
//分页函式 
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); 

?> 
关于分页函式的使用说明 
/* 
#### 检索分页函式 #### 
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进行两次base64_encode()编码后以GET的方式提交 
Varchar $splitstr - 页码条输出字串,执行函式后在相应的位置执行 echo $splitstr; 
函式调用前需获取变量 - 
$paper=$HTTP_GET_VARS[paper]; 
$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"; 
}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); //恢复缺省超时设置 


以下是一些小技巧: 
如何判断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"; 
?> 
---- 
文件下载头部输出如何设定 
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' 
用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"); 
正则匹配中文 
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; 
}
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
4月前
|
PHP
php常见问题,php.ini文件不存在或者找不到,mb_strlen()函数未定义系列问题,dll模块找不到的解决
本文介绍了解决PHP常见问题的步骤,包括定位和创建`php.ini`文件,以及解决`mb_strlen()`函数未定义和DLL模块加载错误的具体方法。
php常见问题,php.ini文件不存在或者找不到,mb_strlen()函数未定义系列问题,dll模块找不到的解决
|
1月前
|
PHP 计算机视觉 UED
Buzz库:PHP图像处理中的异步图像下载和保存
Buzz库:PHP图像处理中的异步图像下载和保存
|
2月前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
82 4
|
2月前
|
关系型数据库 MySQL 数据库连接
PHP内置函数
PHP内置函数
37 5
|
4月前
|
存储 API PHP
php学习笔记-php数组的创建和使用,数组常用函数-day03
关于PHP数组的创建、使用以及常用函数的详细学习笔记。
php学习笔记-php数组的创建和使用,数组常用函数-day03
|
3月前
|
Unix PHP 数据库
PHP日期和时间Date()函数获取当前时间
通过灵活运用 `date()`函数及其丰富的格式选项,PHP开发者可以轻松地在应用程序中处理和展示日期及时间信息。无论是需要精确到秒的完整时间戳,还是仅仅展示日期或时间的某一部分,`date()`函数都能胜任。理解并熟练应用这些格式化技巧,对于提升代码的可读性和维护性至关重要。
82 1
|
3月前
|
Shell 网络安全 数据安全/隐私保护
suuk-s.php.jpg-python 库劫持
suuk-s.php.jpg-python 库劫持
35 0
|
4月前
|
XML SQL PHP
php学习笔记-php字符串及字符串常用函数总结-day04
本文总结了PHP中字符串的三种定义方式和常用字符串处理函数,包括字符串的修剪、转换、长度计算、子串操作、比较、连接、分割及替换等操作。
|
4月前
|
设计模式 存储 算法
PHP中的设计模式:策略模式的深入解析与应用在软件开发的浩瀚海洋中,PHP以其独特的魅力和强大的功能吸引了无数开发者。作为一门历史悠久且广泛应用的编程语言,PHP不仅拥有丰富的内置函数和扩展库,还支持面向对象编程(OOP),为开发者提供了灵活而强大的工具集。在PHP的众多特性中,设计模式的应用尤为引人注目,它们如同精雕细琢的宝石,镶嵌在代码的肌理之中,让程序更加优雅、高效且易于维护。今天,我们就来深入探讨PHP中使用频率颇高的一种设计模式——策略模式。
本文旨在深入探讨PHP中的策略模式,从定义到实现,再到应用场景,全面剖析其在PHP编程中的应用价值。策略模式作为一种行为型设计模式,允许在运行时根据不同情况选择不同的算法或行为,极大地提高了代码的灵活性和可维护性。通过实例分析,本文将展示如何在PHP项目中有效利用策略模式来解决实际问题,并提升代码质量。
|
5月前
|
Linux PHP
Linux CentOS 宝塔 Suhosin禁用php5.6版本eval函数详细图文教程
【8月更文挑战第27天】本文介绍两种禁用PHP执行的方法:使用`PHP_diseval_extension`禁用和通过`suhosin`禁用。由于`suhosin`不支持PHP8,仅适用于PHP7及以下版本,若服务器安装了PHP5.6,则需对应安装`suhosin-0.9.38`版本。文章提供了详细的安装步骤,并强调了宝塔环境下与普通环境下的PHP路径差异。安装完成后,在`php.ini`中添加`suhosin.so`扩展并设置`executor.disable_eval = on`以禁用执行功能。最后通过测试代码验证是否成功禁用,并重启`php-fpm`服务生效。
85 2