`

php 基本的操作

    博客分类:
  • 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);


批量替换文本里面的超级链接
<?php
function 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) = each($types)){
$ret = preg_replace("|($type://)([^\s]*)|ie ", $replace, $ret);
}

return $ret;
}
?>

分享到:
评论

相关推荐

    PHP脚本对数据库的基本操作

    本篇文章将深入探讨如何使用PHP进行MySQL数据库的基本操作。 一、连接MySQL数据库 在PHP中,我们可以使用`mysqli`或`PDO`扩展来连接MySQL数据库。以`mysqli`为例,连接代码如下: ```php &lt;?php $servername = ...

    php对Cookie进行基本操作的类.zip

    这个压缩包文件“php对Cookie进行基本操作的类.zip”提供了一个PHP类,可以帮助开发者更加方便地管理和操作Cookie。 首先,我们要理解Cookie的工作原理。Cookie是由服务器发送到用户的浏览器并存储在本地的一小块...

    Windows下配置Nginx+PHP基本操作(启动、重启和退出)

    总结来说,在Windows系统下配置Nginx和PHP,需要掌握服务的启动、重启和停止等基本操作,并能通过快捷方式和批处理脚本来实现。这些操作虽然看似基础,但对于构建一个稳定可靠的Web开发环境来说至关重要。通过本文的...

    php mysql Dao基本操作

    php mysql dao基本操作,增删改查。以封装成class $my = new MysqlDao(); echo $my-&gt;pdo_delete(MODULE.'_network_list', array('id' =&gt; 17, 'uniacid' =&gt; 6)); $sql = 'select * from '.tablename(MODULE.'_...

    php与mysql基本操作

    下面将详细阐述PHP操作MySQL数据库的基本知识。 1. PHP连接MySQL数据库: 要使用PHP与MySQL交互,首先需要建立一个连接。这可以通过`mysqli_connect()`函数完成,需要提供服务器名、用户名、密码和数据库名作为...

    memcache安装与基本操作详解

    ### Memcache安装与基本操作详解 #### 一、前言 Memcache是一种高性能的分布式内存对象缓存系统,用于加速动态Web应用,减轻数据库负担。本文将详细介绍如何安装配置Memcache,并提供基本的操作示例。 #### 二、...

    PHP MYsql 基本操作

    文档中,记录了Mysql的增删改查操作,包括一些多表查询,分组查询,拼接查询、多数据插入、触发器等

    PHP开发的一套CMS管理系统,非常适用快速二次开发,内置系统权限管理、系统操作日志等基本功能.zip

    PHP开发的一套CMS管理系统,非常适用快速二次开发,内置系统权限管理、系统操作日志等基本功能。满足绝大多数企业日常需求。 PHP开发的一套CMS管理系统,非常适用快速二次开发,内置系统权限管理、系统操作日志等...

    邓炜PHP基本语法(七)文件操作函数

    PHP基本语法(七)文件操作函数 掌握基本文件操作函数; 学会使用常用的文件函数; 掌握如何上传文件; PHP操纵文件一般分为五步进行 1、打开一个文件以供读写 2、从文件中读取数据 3、关闭这个文件 4、执行操作 5...

    PHP中模拟链表和链表的基本操作示例

    PHP中模拟链表和链表的基本操作示例 在编程领域,链表是一种常见的数据结构,它由一系列节点组成,每个节点包含数据和指向下一个节点的指针。链表相较于数组有其独特的优势,例如动态大小、高效的插入和删除操作。...

    PHP Oracle 数据库操作类

    了解这些基本概念后,开发者可以利用这个PHP Oracle 数据库操作类轻松地实现数据的增删改查操作,创建复杂的业务逻辑,同时确保代码的可读性和可维护性。使用面向对象的方式处理数据库操作,不仅使代码更整洁,也...

    浅析PHP对XML文档的基本操作.pdf

    PHP 对 XML 文档的基本操作 本文档旨在介绍 PHP 对 XML 文档的基本操作,包括创建 XML 文档、遍历 XML 文档、添加 XML 数据、修改 XML 数据和删除 XML 数据。 创建 XML 文档 要创建 XML 文档,需要使用 PHP 的 ...

    强大的通用php数据库操作类

    综上所述,这个“强大的通用php数据库操作类”不仅封装了基本的数据库操作,还有可能集成数据验证功能,通过优化代码提高了开发效率和系统性能。配合相应的测试文件、实用工具和配置文件,形成了一个完整的数据库...

    php操作数据库pdf文件

    通过本章节的学习,读者应能掌握如何使用PHP对MySQL数据库进行基本的操作,包括连接数据库、执行SQL语句以及处理结果集。掌握这些技能是构建动态网站和Web应用的基础,也是进一步深入学习PHP和数据库管理系统的前提...

    php操作word内容替换

    本篇文章将深入探讨如何使用PHP操作Word内容替换,并生成新的.doc文档。 PHPWord是一个用PHP编写的库,它允许开发者读取、创建和修改Microsoft Office Open XML (OOXML) 格式的文档,包括.docx文件。这种格式是自...

    PHP操作WORD

    二、PHP操作Word的基本步骤 1. 使用COM组件: - 创建Word对象:`$word = new COM("word.application") or die("无法启动Word");` - 打开文档:`$doc = $word-&gt;Documents-&gt;Open('path_to_file');` - 写入内容:...

    MongoDB基本操作指南

    文档是键值对的集合,这些键值对可以包含各种数据类型,包括基本类型、数组和嵌入的子文档。这种设计鼓励数据的嵌套,减少了查询的复杂性,例如在图2所示的例子中,作品和评论可以被设计为一个集合,评论作为子文档...

    PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】.docx

    标题中的“PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】”指的是一个PHP编程中的数据库操作类,该类使用PDO(PHP Data Objects)扩展,允许开发者与MySQL、SQL Server和Oracle等多种数据库系统进行...

    PHP语言与数据库操作.pdf

    通过以上内容的学习,我们可以了解到使用PHP与MySQL进行交互的基本方法,包括如何连接数据库、创建数据库、删除数据库等操作。这些知识对于Web开发来说非常重要,能够帮助开发者高效地管理和操作数据库。

Global site tag (gtag.js) - Google Analytics