|
  
- UID
- 1
- 帖子
- 738
- 精华
- 28
- 积分
- 14389
- 金币
- 2480
- 威望
- 1647
- 贡献
- 1428
|
一:引论. n ]2 w% b2 g
& K7 M/ P! W8 h8 |3 U% M5 L5 t
在任何计算机设备中,文件是都是必须的对象,而在web编程中,文件的操作一直是web程序员的头疼的地方,而,文件的操作在cms系统中这是必须的,非常有用的,我们经常遇到生成文件目录,文件(夹)编辑等操作,现在我把php中的这些函数做一详细总结并实例示范如何使用.,关于对应的函数详细介绍,请查阅php手册.此处只总结重点.和需要注意的地方.(这在php手册是没有的.)
5 W! x/ ~# n6 ^6 X3 Z- h
. t4 A9 \& z# A9 Z 二:目录操作) \! B7 M* ~: v# y/ `9 w2 }
5 T4 k* W( l0 |* [$ o6 ?9 E! K% m6 i1 T
首先介绍的是一个从目录读取的函数,opendir(),readdir(),closedir(),使用的时候是先打开文件句柄,而后迭代列出:/ d4 {* X+ j8 P
- <?php
- $base_dir = "filelist/";
- $fso = opendir($base_dir);
- echo $base_dir."<hr/>" ;
- while($flist=readdir($fso)){
- echo $flist."<br/>" ;
- }
- closedir($fso)
- ?>
复制代码 ! |: p7 b* d- g8 D
这是讲返回文件目录下面的文件已经目录的程序(0文件将返回false).
* b y3 \ _8 e9 |2 u; U+ |4 [' w4 F& b* L0 `9 X
有时候需要知道目录的信息,可以使用dirname($path)和basename($path),分别返回路径的目录部分和文件名名称部分,可用disk_free_space($path)返回看空间空余空间.
2 ?" Y& P. e! P8 A9 O/ W# [0 [
6 `4 p$ q$ F6 m/ S o创建命令:
3 j3 Y- f8 y; r: }3 ?
0 J9 z+ U+ `3 \6 }2 R1 v, y! F% X,0777是权限码,在非window下可用umask()函数设置.& p; f3 \1 }/ m6 a
) x# w) E$ a r& m- n9 O3 c
将删除路径在$path的文件.
$ y) b% V9 r8 V- l5 z& E/ G/ [
6 n, \ K3 ]3 \4 z# Adir -- directory 类也是操作文件目录的重要类,有3个方法,read,rewind,close,这是一个仿面向对象的类,它先使用的是打开文件句柄,然后用指针的方式读取的.,这里看php手册:5 ?. U+ n" Y3 u" l" x
- <?php
- $d = dir("/etc/php5");
- echo "Handle: " . $d->handle . "\n";
- echo "Path: " . $d->path . "\n";
- while (false !== ($entry = $d->read())) {
- echo $entry."\n";
- }
- $d->close();
- ?>
复制代码 1 A7 s; d% H3 H3 `
输出:
* z" O: J7 E/ L; r% Y- Handle: Resource id #2
- Path: /etc/php5
- .
- ..
- apache
- cgi
- cli
复制代码 * s6 L3 k: t% [- V- k, M. y$ Q& d& n
文件的属性也非常重要,文件属性包括创建时间,最后修改时间,所有者,文件组,类型,大小等
& B- s! a. K8 C" {- A% G) a: Y: j7 o8 f* X9 F$ H
下面我们重点谈文件操作.* N( J) r7 m0 M# {/ t
& r) f8 m" x4 t. |三:文件操作. b3 d" w! a' f3 q2 h/ ]$ @
7 u9 L9 Y% a" V0 `$ y
● 读文件
6 f, g) G1 Q+ H$ P3 z" S# ]) C
. \; P% P0 j, p5 B6 ]: O首先是一个文件看能不能读取(权限问题),或者存在不,我们可以用is_readable函数获取信息.: / O" S0 {4 u/ ^
- <?php
- $file = 'dirlist.php';
- if (is_readable($file) == false) {
- die('文件不存在或者无法读取');
- } else {
- echo '存在';
- }
- ?>
复制代码 ; O# c3 `9 O# H2 m" D4 k- {- \6 N. Z' |
0 p6 j! S% H+ P2 }% Y9 c判断文件存在的函数还有file_exists(下面演示),但是这个显然无is_readable全面.,当一个文件存在的话可以用
6 S! Y: ~$ E5 b: c, c2 y& Z( h h D4 l1 A# V# I0 Y1 p
- <?php
- $file = "filelist.php";
- if (file_exists($file) == false) {
- die('文件不存在');
- }
- $data = file_get_contents($file);
- echo htmlentities($data);
- ?>
复制代码
5 Z7 ^! X ?% i但是file_get_contents函数在较低版本上不支持,可以先创建文件的一个句柄,然后用指针读取全部:
( W5 U! ^$ |; _8 Q+ M6 F+ m/ Q5 |5 a5 K
- $fso = fopen($cacheFile, 'r');
- $data = fread($fso, filesize($cacheFile));
- fclose($fso);
复制代码
/ `" F% [% R) I5 h还有一种方式,可以读取二进制的文件:
* | K" O, w* z! y- ~- $data = implode('', file($file));
复制代码
5 F! g' i1 J/ R0 L5 t' R ?" \● 写文件
: q2 E6 v8 d' x+ ?
2 [- N/ m& x# h5 K) l& `和读取文件的方式一样,先看看是不是能写:, q( D/ M$ i" V: I2 L9 c
; n+ D2 w1 w& H t0 ~
- <?php
- $file = 'dirlist.php';
- if (is_writable($file) == false) {
- die("我是鸡毛,我不能");
- }
- ?>
复制代码 ( T! e2 |( S! X; ~
6 K, N7 ~- F% x; ?6 j- z
能写了的话可以使用file_put_contents函数写入:. i' { r, X) W, d2 V4 x: t
- <?php
- $file = 'dirlist.php';
- if (is_writable($file) == false) {
- die('我是鸡毛,我不能');
- }
- $data = '我是可鄙,我想要';
- file_put_contents ($file, $data);
- ?>
复制代码
' R: K: \$ H# ?- g: q; l6 ~file_put_contents函数在php5中新引进的函数(不知道存在的话用function_exists函数先判断一下)低版本的php无法使用,可以使用如下方式:+ H: g7 T& J2 e g! r# e+ |
6 g9 I- Z" Q$ I* S- $f = fopen($file, 'w');
- fwrite($f, $data);
- fclose($f);
复制代码 : M0 ^6 y3 S4 G+ E. x$ ^9 @
: |* K$ e2 _: m替换之.
) F+ B9 ]! O: a7 o6 s8 a- l/ W( R A* \9 T
写文件的时候有时候需要锁定,然后写:
& }5 Q9 }+ ?/ R( z: W- I' d# d- function cache_page($pageurl,$pagedata){
- if(!$fso=fopen($pageurl,'w')){
- $this->warns('无法打开缓存文件.');//trigger_error
- return false;
- }
- if(!flock($fso,LOCK_EX)){//LOCK_NB,排它型锁定
- $this->warns('无法锁定缓存文件.');//trigger_error
- return false;
- }
- if(!fwrite($fso,$pagedata)){//写入字节流,serialize写入其他格式
- $this->warns('无法写入缓存文件.');//trigger_error
- return false;
- }
- flock($fso,LOCK_UN);//释放锁定
- fclose($fso);
- return true;
- }
复制代码
7 r3 s# ^+ [5 X4 s5 Y● 复制,删除文件
/ s; |/ [* z% i( Z
* X( [$ T1 c- e7 Lphp删除文件非常easy,用unlink函数简单操作:; K8 H+ o- O8 I6 R% R ^
0 n# [2 O) F( f) I7 V' D8 p
- <?php
- $file = 'dirlist.php';
- $result = @unlink ($file);
- if ($result == false) {
- echo '蚊子赶走了';
- } else {
- echo '无法赶走';
- }
- ?>
复制代码 " D2 A y# z( M2 b+ a* f4 Y: |
即可.2 o. n) ^, S% _1 E7 S- e m
O. G" @6 _9 \, c5 r7 T复制文件也很容易:7 c) _& p9 U5 O* n2 S2 u
! X: m* ^7 C0 j# a+ C$ V" n* g; L
- <?php
- $file = 'yang.txt';
- $newfile = 'ji.txt'; # 这个文件父文件夹必须能写
- if (file_exists($file) == false) {
- die ('小样没上线,无法复制');
- }
- $result = copy($file, $newfile);
- if ($result == false) {
- echo '复制记忆ok';
- }
- ?>
复制代码 : s* _3 F1 b- l3 b" h
可以使用rename()函数重命名一个文件夹.其他操作都是这几个函数组合一下就能实现的.1 n7 J$ o. ^* f
8 y+ I) H) D+ N: A' {
● 获取文件属性 4 D8 p) \6 y( e5 g7 `
. X# N2 i- I2 B! |我说几个常见的函数:2 n; N1 a1 l0 }* @* `
获取最近修改时间:! c0 o! m$ o! ?) \2 P+ C0 }
( H! V/ R! o" P: ~' m- <?php
- $file = 'test.txt';
- echo date('r', filemtime($file));
- ?>
复制代码
% F6 N# X" {$ _; b3 I
0 Y& N9 i8 W7 F, N返回的说unix的时间戳,这在缓存技术常用.
: e5 v* l& e. Y5 Z
( {) o) C( a& z' B相关的还有获取上次被访问的时间fileatime(),filectime()当文件的权限,所有者,所有组或其它 inode 中的元数据被更新时间,fileowner()函数返回文件所有者
, }" R8 ?9 l6 R; `3 K! O+ J" C$owner = posix_getpwuid(fileowner($file));' s g3 z6 d2 p @8 t# Y* H3 m4 z
(非window系统),ileperms()获取文件的权限,+ w9 J6 ~9 r7 I5 P0 H" o
- <?php
- $file = 'dirlist.php';
- $perms = substr(sprintf('%o', fileperms($file)), -4);
- echo $perms;
- ?>
复制代码 : w5 s- [5 X4 l5 C& H
filesize()返回文件大小的字节数:
- |! S5 _! ^3 [* ~6 \% o3 Q: X" ^- <?php
- // 输出类似:somefile.txt: 1024 bytes
- $filename = 'somefile.txt';
- echo $filename . ': ' . filesize($filename) . ' bytes';
- ?>
复制代码 9 \; F, S! O& Z9 ]- Q
获取文件的全部信息有个返回数组的函数stat()函数:) Y: w: r3 w; R$ b( ]. X1 Z) A
- <?php
- $file = 'dirlist.php';
- $perms = stat($file);
- var_dump($perms);
- ?>
复制代码
+ H2 l k9 g" X0 r9 M; F那个键对应什么可以查阅详细资料,此处不再展开.. g0 B& I! M2 u+ p8 }6 {
* B4 r3 O8 q4 R( k! N, Z, s. W四:结束语
9 Z, D o' U9 X% r
+ e# y6 i$ h! G+ e上面我简要的总结了一下几个文件操作,如果您熟练掌握以上列出的函数,已经在操作的时候没什么大的问题,php文件操作的函数变化比较快,现在已经非常强大了,文件这部分也是学习php非常重要的一部分,希望不要忽略. |
|