PHP与服务器文件系统的简单交互

 更新时间:2016年10月21日 11:51:59   作者:Al_assad  
这篇文章主要介绍了PHP与服务器文件系统的简单交互的相关资料,非常不错,具有参考借鉴价值,感兴趣的朋友一起看看吧

1、php.ini中关于文件上传的设置指令

2、文件上传过程

(1)上传文件提交表单html代码:

<!--向服务器上传文件的HTML表单(限制为文本文件)--> 
<!DOCTYPE html> 
<html lang="en"> 
<head> 
<meta charset="UTF-8"> 
<title>Adminstration - upoload new files</title> 
</head> 
<body> 
<h1>Upload new files</h1> 
<form action="upload.php" method="post" enctyple="multipart/form-data" > 
<!--enctyple:规定在发送到服务器之前对表单数据进行编码的方式(在上传控件时必须按照以上方式设置该属性)--> 
<div> 
<input type="hidden" name="MAX_FILE_SIZE" value="1000000"> 
<!--规定传输文件的最大字节数--> 
<label for="userfile">Upload a file</label> 
<!--在<label>内点击文本,会触发该控件,此时浏览器会自动对焦到标签for属性所指向的表单控件上面--> 
<input type="file" name="userfile" id="userfile"> 
<!--id属性为<label>标签for所指向控件元素的id号--> 
<input type="submit" value="Send File"> 
</div> 
</form> 
</body> 
</html>

(2)php处理上传文件代码

①在php脚本中,需要处理的数据保存在超级变量数组$_FILES中,开启register_globals指令可以直接通过变量名访问这些信息;

②假如表单变量名为“username“则有:

$_FILES['userfile']['tmp_name']:储存文件在Web服务器中的临时保存位置;
$_FILES['userfile']['name']:储存用户系统中文件的名称;
$_FILES['userfile']['size']:储存文件的大小;
$_FILES['userfile']['type']:储存文件的类型;
$_FILES['userfile']['error]:储存任何与文件上传相关的错误代码;

错误类型说明:

UPLOAD_ERR_INI_SIZE:1,上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。
UPLOAD_ERR_FORM_SIZE:2,上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。
UPLOAD_ERR_PARTIAL:3,文件只有部分被上传。
UPLOAD_ERR_NO_FILE:4,没有文件被上传。
UPLOAD_ERR_NO_TMP_DIR:6,找不到临时文件夹。PHP 4.3.10 和 PHP 5.0.3 引进。
UPLOAD_ERR_CANT_WRITE:7,文件写入失败。PHP 5.1.0 引进。

③php代码

<?php 
//检验文件传输异常 
if($_FILES['userfile']['error']>0){ 
echo 'Problem'; 
switch($_FILES['userfile']['error']){ 
case 1: echo 'File exceeded upload_max_filesize';break; 
case 2: echo 'File exceeded max_file_size';break; 
case 3: echo 'File only partially upload';break; 
case 4: echo 'No file uploaded';break; 
case 6: echo 'Cannot upload file: No temp directory specified';break; 
case 7: echo 'Upload failed:Cannot write to disk';break; 
} 
exit; 
} 
//检验传输的文件是否为文本文件 
if($_FILES['userfile']['type'] != 'text/plain'){ 
echo 'Problem: file is not plain text'; 
exit; 
} 
//将上传文件包含在服务器中/uploads/的目录下(该目录必须独立于Web文档树) 
$upfile = '/uploads/'.$_FILES['userfile']['name']; //在指定目录下以传输文件的文件名创建一个新文件 
if(is_uploaded_file($_FILES['userfile']['tmp_name'])){ 
if(! move_uploaded_file($_FILES['userfile']['tmp_name'],$upfile)){ //将传输文件的临时文件移动到创建的新文件 
echo 'Problem: Could not move file to destination directory'; 
exit; 
} 
} 
else{ 
echo 'Problem: Possible file upload attack.Filename:'; 
echo $_FILES['username']['name']; 
exit; 
} 
echo "File uploaded seuucessfully<br/><br/>"; 
//对传输文件清除html和php标记 
$contents = file_get_contents($upfile); //将文件内容提取为一个字符串; 
$contents = strip_tags($contents); //对该字符串擦除html和tags标记; 
file_put_contents($_FILES['userfile']['name'],$contents); //将该字符串重新写入文件中; 
//在浏览器上显示传输的文本文件内容 
echo "<p>Preview of uploaded file contents:<br/><hr>>"; 
echo nl2br($contents); 
echo "</br></hr>";

3、使用目录函数

(1)从目录中读取文件名

①使用opendir(),readdir(),closedir()函数;

<?php 
$current_dir = '/uploads/'; //创建目录url对象 
$dir = opendir($current_dir); //打开目录,结果返回一个目录对象 
echo "<p>Upload directory is $current_dir</p>"; 
echo "<p>Directory Listing:</p><ul>"; 
while(($file = readdir($dir)) !== false){ //读取目录对象 
if($file != "." && $file != ".."){ //过滤当前目录和上一级目录 
echo "<li>$file</li>"; 
echo "<a href=\"filedetails.php?file=\'.$file.\'\">".$file."</a><br/>"; 
} 
} 
echo "</ul>"; 
closedir($dir); //关闭目录; 
?>

②使用php的dir类

<?php 
$current_dir = '/uploads/'; //创建目录url对象 
$dir = dir($current_dir); //创建dir对象 
echo "<p>Handle is $dir->handle</p>"; 
echo "<p>Upload directory is $current_dir</p>"; 
echo "<p>Directory Listing:</p><ul>"; 
while(($file = $dir->read()) !== false){ //通过dir对象读取目录下的文件名 
if($file != "." && $file != ".."){ 
echo "<li>$file</li>"; 
} 
} 
echo "</ul>"; 
$dir->close(); //关闭目录 
?>

(2)使用scandir()函数对文本名称进行字母表的排序方式

<?php 
$current_dir = '/uploads/'; //创建目录url对象 
$files1 = scandir($current_dir); //将指定目录下的文件名保存为一个数组,默认以字母升序排序 
$files2 = scandir($current_dir,1); //将指定目录下的文件名保存为一个数组,以字母降序排序 
echo "<p>Upload directory is $current_dir</p>"; 
echo "<p>Directory Listing in alphabetical order,ascending:</p><ul>"; 
foreach($files1 as $file1) { 
if($file1 != "." && $file1 != "..") 
echo "<li>$file1</li>"; 
} 
echo "</ul>"; 
?>

(3)获取当前目录的其他信息

dirname($path):返回路径的目录部分;

basename($path):返回路径的名称部分;

disk_free_space($path):返回路径所在磁盘可以保存上传文件的容量;

(4)创建和删除目录

①mkdir():创建目录;

代码:

$oldumask = umask(0); //重置当前权限码
mkdir("/tmp/testing",0777); //创建目录
umask($oldumask); //恢复当前权限码

②rmdir():删除目录;

代码:

rmdir("/temp/testing");
或rmdir("c:\\tmp\\testing');

※要删除的目录必须是空目录;

4、与文件系统的交互

(1)获取文件信息:

while(($file = readdir($dir)) !== false){ 
echo "<a href=\"filedetails.php?file=\'.$file.\'\">".$file."</a><br/>";
}
<?php 
$current_dir = '/uploads/'; 
$file = basename($file); //获取文件文件名 
echo "<h1>Details of file</h1>"; 
echo "<h2>File data</h2>"; 
echo 'File last accessed: '.date('j F Y H:i',fileatime($file))."<br>"; //返回最近访问的时间戳 
echo 'File last modifixed: '.date('j F Y H:i',filemtime($file))."<br>"; //返回最近修改的时间戳 
$user = posix_getpwuid(fileowner($file)); //返回用户标识uid 
echo 'File owner: '.$user['name']."<br/>"; 
$group = posix_getgrgid(filegroup($file)); //返回组织标识gid 
echo 'File group: '.$group['name']."<br/>"; 
echo 'File permissions: '.decoct(fileperms($file))."<br/>"; //返回8位的权限码 
echo 'File type'.filetype($file)."<br/>"; //返回文件类型 
echo 'File size'.filesize($file)."<br/>"; //返回文件字节数 
echo "<h2>File Tests</h2>"; 
echo 'is_dir?'.(is_dir($file) ? 'true':'false')."<br/>"; 
echo 'is_executable?'.(is_executable($file) ? 'true':'false')."<br/>"; //判断文件是否可执行; 
echo 'is_file?'.(is_file($file) ? 'true':'false')."<br/>"; 
echo 'is_link?'.(is_link($file) ? 'true':'false')."<br/>"; 
echo 'is_readable?'.(is_readable($file) ? 'true':'false')."<br/>"; 
echo 'is_writable?'.(is_writable($file) ? 'true':'false')."<br/>"; 
?>

(2)更改文件属性

chgrp(file,group):修改文件的分组;

chmod(file,permissions):修改文件的权限;

chown(file,user):修改文件的所有者;

(3)创建、删除和移动文件

bool touch($filename,[int time,[ int atime]]):创建一个文件(time指定创建时间戳,atime指定可选时间戳)

unlink($filename):删除一个文件

copy($source_path,$destination_path):复制一个文件

rename($oldfile,$newfile):重命名一个文件;

(4)使用程序执行函数

①String exec(String command[ ,array result [ ,int result_value]])

返回命名结果的最后一行,result变量可以返回字符组数,这些字符串代表输出的每一行,result_value获取返回代码;

②void passthru(String command[ ,int result_value])

结果直接输出到浏览器;

③String system(string command[ ,int return_value])

输出结果到浏览器,返回命令结果的最后一行或false;

※在用户提交的数据包括执行命令的一部分,应该进行以下包装:

system(escapeshellcmd($command));

5、与环境变量交互

phpinfo()函数:获取php的所有变量列表;

getenv("$key_name"):

setenv("$key_name=$value");

以上所述是小编给大家介绍的PHP与服务器文件系统的简单交互,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • 大家须知简单的php性能优化注意点

    大家须知简单的php性能优化注意点

    通过本文给大家介绍在什么情况下可能遇到性能问题,php性能问题的解决方向及优化点,对php性能优化注意点相关知识感兴趣的朋友一起学习吧
    2016-01-01
  • php xml留言板 xml存储数据的简单例子

    php xml留言板 xml存储数据的简单例子

    php xml留言板 xml存储数据的简单例子 php操作xml的简单留言板,带分页,仅供参考
    2009-08-08
  • 在PHP站点的页面上添加Facebook评论插件的实例教程

    在PHP站点的页面上添加Facebook评论插件的实例教程

    这篇文章主要介绍了在PHP站点的页面上添加Facebook评论插件的实例教程,这样用户便可以以Facebook的用户身份在Facebook样式的评论表单上发表评论,需要的朋友可以参考下
    2016-01-01
  • PHP微信支付开发实例

    PHP微信支付开发实例

    这篇文章主要为大家详细介绍了PHP微信支付开发过程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • thinkPHP5(TP5)实现改写跳转提示页面的方法

    thinkPHP5(TP5)实现改写跳转提示页面的方法

    这篇文章主要介绍了thinkPHP5(TP5)实现改写跳转提示页面的方法,结合实例形式分析了thinkPHP5跳转提示页面的修改步骤与相关操作注意事项,需要的朋友可以参考下
    2017-10-10
  • CI框架中libraries,helpers,hooks文件夹详细说明

    CI框架中libraries,helpers,hooks文件夹详细说明

    CodeIgniter 是一个小巧但功能强大的 PHP 框架,作为一个简单而“优雅”的工具包,它可以为 PHP 程序员建立功能完善的 Web 应用程序。今天我们来看看CI框架中几个文件夹都是干什么用的
    2014-06-06
  • 详解如何实现Laravel的服务容器的方法示例

    详解如何实现Laravel的服务容器的方法示例

    这篇文章主要介绍了详解如何实现Laravel的服务容器的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • php封装的smarty类完整实例

    php封装的smarty类完整实例

    这篇文章主要介绍了php封装的smarty类,针对Smarty的基本操作技巧进行了封装整理,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-10-10
  • PHP中的Streams详细介绍

    PHP中的Streams详细介绍

    这篇文章主要介绍了PHP中的Streams详细介绍,本文介绍了Stream 基础知识、php:// Streams包装类、Stream上下文等内容,需要的朋友可以参考下
    2014-11-11
  • 详解PHP中curl_multi并发的实现

    详解PHP中curl_multi并发的实现

    这篇文章主要介绍了详解PHP中curl_multi并发的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06

最新评论