代码实例如下:
实例
<?php // 目录遍历操作: // 1. 传统过程函数: opendir(),readdir(),closedir() // 2. 目录扫描器: scandir() // 第一种方式: 传统目录函数 // // 第一步: opendir('目录')打开目录,成功返回资源,失败返回false // 第二步: readdir($dir)读取目录内容,世功返回文件名,失败返回false // 第三步: closedir($dir)关闭当前目录 $dir = opendir('../0827') or die('打开失败'); $dir = opendir('./') or die('打开失败'); //.或./当前目录 while (false != ($file = readdir($dir))) { print $file."<br>"; print nl2br($file."\n"); if ($file != "." && $file != "..") { print $file."<br>"; } } closedir($dir); echo '<hr>'; /** * 第二种方式:将目录内容保存到数组中进行遍历 * 第一步:scandir($dir)将目录转数组中保存 * 第二步:遍历目录数组 */ //读到一个目录内容到数组中: $fileArr = scandir('../0827/'); print_r($fileArr); foreach ($fileArr as $file) { if ($file != "." && $file != "..") { echo "$file<br>"; } }
运行实例 »
点击 "运行实例" 按钮查看在线实例
实例
<form action="<?php echo htmlspecialchars($_SERVER['PHP_SELF']); ?>" method="POST" enctype="multipart/form-data"> <!-- 用隐藏域设置允许上传的文件大小,仅考参考 --> <input type="hidden" name="MAX_FILE_SIZE" value="542488"> <fieldset> <legend align="center">文件上传</legend> <p><strong>选择文件:</strong><input type="file" name="upload"></p> </fieldset> <p align="center"><button type="submit" name="submit" >上传</button></p> </form> <?php //检测请求类型是否POST,如果不是应该提示用户类型不对 if ($_SERVER['REQUEST_METHOD'] == 'POST') { //检测是否有文件被上传 if (isset($_FILES['upload'])) { //设置允许上传的文件类型 $allow = ['image/jpg','image/jpeg', 'image/png']; if (in_array($_FILES['upload']['type'], $allow)) { //将文件先移动到临时目录 if (move_uploaded_file($_FILES['upload']['tmp_name'], "upload/{$_FILES['upload']['name']}")){ //上传成功 echo "<script>alert('文件上传成功')</script>"; } }else { //提示格式不对 echo "<script>alert('仅允许上传jpg和png格式的图片')</script>"; } } //对上传错误进行处理 if ($_FILES['upload']['error'] > 0 ) { echo '<p>错误原因是:<strong>'; switch ($_FILES['upload']['error']) { case 1: echo '文件超过了php.ini配置中设置的大小'; break; case 2: echo '文件超过了表单中常量设置的大小'; break; case 3: echo '仅有部分文件被上传'; break; case 4: echo '没有文件被上传'; break; case 6: echo '没有可用的临时文件夹'; break; case 7: echo '磁盘已满,写入失败'; break; case 8: echo '上传意外中止'; break; default: echo '系统未知错误'; break; } echo '</strong></p>'; //保险起见,最好把创建的临时文件删除,当然系统也会在结束会话时自动清空 if (file_exists($_FILES['upload']['tmp_name']) && is_file($_FILES['upload']['tmp_name'])) { unlink($_FILES['upload']['tmp_name']); } } } else { echo '1'; } ?>
运行实例 »
点击 "运行实例" 按钮查看在线实例
课堂总结:
通过本堂课的学习,我大致了解了文件操作的具体方法和步骤,也了解了对上传错误进行处理的九种方式;
但是还没有完全掌握目录的遍历和文件上传与检测;其中有很多方面的原因:第一,没有及时复习当天的
课程,导致自己听老师讲课时不知所云;第二,过于依赖于老师的课堂文件源码和录播视频,心想反正有录播和文件源码,所以使自己养成了拖延症总想把作业留到第二天甚至是第三天去做,这是一个非常不好的习惯,我以后一定加紧改正。