$fp=fopen("test.txt","r");
//以只读方式打开文件,将文件指针指向文件头
$fp=fopen("test.txt","r+");
//以读写方式打开文件,将文件指针指向文件头
$fp=fopen("test.txt","w");
//写入方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建
$fp=fopen("test.txt","w+");
//以读写方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建
$fp=fopen("test.txt","a");
//以写入方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建
$fp=fopen("test.txt","a+");
//以读写方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建
$fp=fopen("test.txt","wb+");
//以写入方式打开二进制文件,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建
$fp=fopen("c: est est.txt","r");
//在windows平台上,要转义文件路径中的每个反斜线,或者用斜线
$fp=fopen("http://www.domain.com/","r");
//以只读方式打开web地址
$fp=fopen("ftp://username:password@domain.com/test.txt","r");
//与ftp服务器连接,以username和password登录服务器
/*
本实例代码无输出结果
*/
$fp=fopen("test.txt","r"); //打开文件
$msg=fread($fp,filesize("test.txt")); //读取文件内容到变量
print "$msg"; //输出文件内容
fclose($fp); //关闭文件
//
$fp=popen("test.txt","r"); //以只读方式打开文件
$fp=popen($_post['command'],'r');
$read=fread($fp,2096); //读取内容
echo $read; //输出内容
pclose($fp); //关闭文件
//这里用popen执行命令,命令是以post方式提交的参数,并返回执行结果。需要注意的是如果未找到要执行的命令,会返回一个合法的资源。它允许访问shell返回的任何错误信息。在打开了安全模式时,只能执行在safe_mode_exec_dir之内的程序,不能在指向程序的路径中包含..成分,即不能在指定目下外执行命令。
$fp=popen($_post['command'],'r'); //打开进程文件
$read=fread($fp,2096); //读取进程文件指针到变量
echo $read; //输出内容
pclose($fp); //关闭进程文件
//
$file="test.txt"; //定义文件
if(file_exists($file)) //判断文件是否存在
{
echo "下面清除缓存";
}
echo "<p>";
clearstatcache(); //清除文件状态缓存
if(file_exists($file)) //判断文件是否存在
{
die('清除完毕');
}
//
$filename="test.txt"; //定义文件
$user="admin"; //定义用户
chgrp($filename,$group); //改变文件/test/testfile.txt的所有者为"admin"
//
chmod("/test/testfile.txt",0600);
//只有文件所有者拥有读写权限
chmod("/test/testfile.txt",0644);
//文件所有者拥有读写权限,其他用户拥有只读权限
chmod("/test/testfile.txt",0755);
//文件所有者拥有所有权限,其他用户拥有读和执行权限
chmod("/test/testfile.txt",0750);
//文件所有者拥有所有权限,文件所有者所在用户组拥有读和执行权限
//
$file="test.txt"; //定义文件
delete($file); //删除文件
//在php编程时一般还是用unlink函数来删除文件。
//
//以下代码实现文件上传功能,首先用move_uploaded_file函数上传文件;如果失败就用copy函数上传文件,上传到指定目录并修改目录属性。
//使用此代码要有文件上传权限,还要定义$path上传路径。另外必须有上传内容。单独使用,无输出内容
if(function_exists('move_uploaded_file') && move_uploaded_file($attachment,$path))
{
chmod($path,0666); //改变文件访问模式
$attachment=$path;
}
elseif(copy($attachment,$path)) //如果move_upload_file就用cope()
{
chmod($path,0666); //改变文件访问属性
$attachment=$path;
}
语法
opendir(path,context)
*/
$d=dir("c:windows"); //打开目录,并赋值给变量
echo "handle:".$d->handle."n"; //输出目录的handel属性
echo "<p>";
echo "path:".$d->path."n"; //输出目录的path属性
echo "<p>";
while(false!==($entry=$d->read())) //通过循环读取对象的方法
{
echo $entry."n";
}
$d->close(); //关闭目录句柄
//
$dir="c:windows"; //定义目录
if(is_dir($dir)) //如果变量为目录
{
if($dh=opendir($dir)); //如果成功打开目录
{
echo "目录".$dir."成功打开";
}
}
echo "<br>";
closedir($dh); //关闭打开的目录句柄
echo "目录".$dir."已经关闭!";
///
$dir=" c:windows "; //定义目录变量
if(is_dir($dir)) //判断变量是否为目录
{
if($dh=opendir($dir)) //判断目录是否成功打开
{
while(($file=readdir($dh))!==false) //循环读取目录中的文件信息
{
echo "filename:$file,filetype:".filetype($dir.$file)."n"; //输出文件名及文件类型
}
closedir($dh); //关闭目录句柄
}
}
///
if($handle=opendir('web')) //如果目录顺利打开
{
while(false!==($file=readdir($handle))) //循环读取目录中的条目
{
if($file!="."&&$file!="..") //如果文件不为当前或上级目录
{
echo "$filen"; //输出文件名称
}
}
closedir($handle); //关闭目录句柄
}
//
if($handle=opendir('08')) //如果目录顺利打开
{
while(false!==($file=readdir($handle))) //循环读取目录中的条目
{
if($file!="."&&$file!="..") //如果文件不为当前或上级目录
{
echo "$filen"; //输出文件名称
}
}
rewind($handle); //倒回目录句柄
if(readdir($handle)) //判断是否倒回成功
{
echo "倒回成功";
}
else
{
echo "倒回失败";
}
closedir($handle); //关闭目录句柄
}
//如果要对目录按字母排序如一
$files1=scandir($dir); //按字母升序列出内容到数组
$files2=scandir($dir,1); //按字母降序列出内容到数组
$file="test.txt"; //定义文件
echo fileowner($file); //获取文件所有者
/*
fileowner() 函数返回文件的所有者。
若成功,则返回文件所有的用户 id。若失败,则返回 false。用户 id 以数字格式返回。
语法
fileowner(filename)
输出结果类似于:
0
*/
//以下函数实现删除所有".jpg"图片文件
foreach(glob("*.jpg")as $filename) //查找与模式"*.jpg"匹配的文件
{
echo "$filename size ".filesize($filename)."n"; //输出文件信息
unlink($filename); //删除文件
}
/*
glob() 函数返回匹配指定模式的文件名或目录。
该函数返回一个包含有匹配文件 / 目录的数组。如果出错返回 false。
*/
//将test.txt的最后修改时间改为2007年4月15日19点5分10秒
touch("test.txt",mktime(19,5,10,4,15,2007));
$file="test.txt"; //定义文件
echo fileperms($file); //获取文件权限
/*
fileperms() 函数返回文件或目录的权限。
若成功,则返回文件的访问权限。若失败,则返回 false。
语法
fileperms(filename)
*/
//
$oldname="test.txt"; //定义原文件
$newname="test.txt.bak"; //定义修改后的文件名
if(rename($oldname,$newname)) //进行改名操作并对结果判断
{
echo "改名成功!"; //输出相应信息
}
else
{
echo "改名失败!";
}
/*
rename() 函数重命名文件或目录。
若成功,则该函数返回 true。若失败,则返回 false。
语法
rename(oldname,newname,context)
注释:在 php 4.3.3 之前,rename() 不能在基于 *nix 的系统中跨磁盘分区重命名文件。
注释:用于 oldname 中的封装协议必须和用于 newname 中的相匹配。
注释:对 context 的支持是 php 5.0.0 添加的。
*/
$temp[0]="abc";
$temp[1]=123;
$temp[2]="us.";
$temp[3]=5;
$temp[4]=58;
$temp[5]="cs";
//以上代码定义一个数组,其中既有数字也有字符串
echo "数组temp的内容为:";
echo "<p>";
//通过循环输出数组内容
for($i=0;$i<count($temp);$i++)
{
echo $temp[$i];
echo ",";
}
echo "<p>";
echo "经过preg_grep()处理过之后的新数组为:";
$temp2=preg_grep("/^(d)d*/",$temp); //使用preg_grep进行处理
//上式的正则表达式模式中"//"为定界符,其内容为所有整数元素
echo "<p>";
print_r($temp2); //通过循环输出新数组内容
//
$str='string'; //定义字符串
$chars=preg_split('//',$str,-1,preg_split_no_empty); //用正则表达式执行分割操作
print_r($chars); //输出结果数组:array([0]=>s[1]=>t[2]=>r[3]=>i[4]=>n[5]=>g)
//
$string="april 15, 2003"; //定义字符串
$pattern="/(w+)(d+),(d+)/i"; //定义匹配模式
$replacement="${1}1,$3"; //定义替换内容
print preg_replace($pattern,$replacement,$string); //输出结果april1,2003
//
$text="april fools day is 04/01/2002n"; //定义字符串
$text.="last christmas was 12/24/2001n"; //字符串更新
$pattern="|(d{2}/d{2}/)(d{4})|"; //定义匹配模式
function next_year($matches) //定义回调函数
{
return $matches[1].($matches[2]+1); //返回值
}
$result=preg_replace_callback($pattern,"next_year",$text); //用回调函数执行搜索替换
echo $result; //输出结果"april fools day is 04/01/2003 last christmas was 12/24/2002"
//
$keywords="'php教程'"; //定义字符串
$keywords=preg_quote($keywords,"'"); //转义其中的"'"
echo $keywords;
?>
echo getcwd()."n"; //取得当前工作目录
echo "<br>";
chdir('08'); //改变工作目录
echo getcwd() . "n"; //再次取得当前工作目录
getcwd() 函数返回当前目录。
若成功,则返回当前工作目录,否则返回 false。
语法
getcwd()
//
echo getcwd() . "n"; //取得当前工作目录
chdir('web'); //改变工作目录
echo getcwd() . "n"; //再次取得工作目录
chdir() 函数把当前的目录改变为指定的目录。
若成功,则该函数返回 true,否则返回 false。
语法
chdir(directory)