この記事では、主に PHP ファイルのアップロード、ダウンロード、削除の例を詳しく紹介します。興味のある方は参考にしてください。PHP ファイルのアップロード、ダウンロード、削除の例の一般的な考え方は次のとおりです。具体的な内容は以下の通りです
2. ファイルを表示する領域を作成します
3.ファイルをアップロードします
4. サーバーはファイルデータを受信します
5. データを処理して、アップロードされたファイルにエラーがあるかどうかを確認します
1) アップロードされたファイルが php.ini のサイズを超えています。upload_max_filesize オプションの制限値を超えています。
2) アップロードされたファイルのサイズが HTML フォームの MAX_FILE_SIZE オプションで指定された値を超えています。
3)。ファイルがアップロードされました
5). ファイルの書き込みに失敗しました
6). アップロードされたファイルを一時フォルダーから保存用に指定したフォルダーに移動します
ステップ 4、5、6 を関数にして直接呼び出すことができます
注: ファイルのアップロード ページに php コードを埋め込みたい場合、ファイル拡張子は html にすることはできませんが、.php
2 です。ファイルのダウンロード
3.クライアント
//1.重设响应类型
$info = getimagesize($rootPath.$file);
header("Content-Type:".$info['mime']);
//2.执行下载的文件名
header("Content-Disposition:attachment;filename=".$file);
//3.指定文件大小
header("Content-Length:".filesize($rootPath.$file));
//4.响应内容
readfile($rootPath.$file);
1.. クライアントはファイルを転送します
サーバーはファイルを受信します
2.ファイル名を入力し、ファイルのパスを追加します。3. unlink 関数を使用して、ファイルの削除操作を実行します画像のアップロード、ダウンロード、削除の簡単な例を示します。
html+php埋め込み:
<!-- 选择上传文件区域--> <p id="p1"> <form action="upLoadFile.php" method="post" enctype="multipart/form-data"> <p id="p2"><input type="text" id="show" /></p> <p id="p3"> <span class="text">选择文件</span> <input type='hidden' name='MAX_FILE_SIZE' value='100000000'> <!--表单上传文件的大小限制<100M,也可以设置其它值--> <input type="file" id="upfile" name="file" /> </p> <input type="submit" value="上传" class="upload" /> </form> </p> <!-- 选择上传文件区域结束--> <!-- 上传文件显示区域--> <p id="show-file"> <ul id="ul-list"> <!-- 内嵌php代码,为了动态显示上传的文件--> <?php //1.打开目录 $dir = opendir('upload'); //2.遍历目录 $i = 0; while($file = readdir($dir)) { if($file == '.'||$file == '..') continue; echo "<li><img src='upload/{$file}' width='120' height='100'> <p><a href='deleteFile.php?name={$file}'>删除</a></span></p> <span><a href='download.php?name={$file}'>下载</a></span></li>"; } //3.关闭目录 closedir($dir); ?> <!-- 内嵌php代码结束--> </ul> </p> <!-- 上传文件显示区域结束-->
*{margin:0;padding:0;} ul,li{list-style: none;} /*最外层的p,目的是包住选择文件按钮,显示框和上传文件按钮*/ #p1{width:405px;height:38px;position: relative;margin:40px auto;} /*第二层p包住显示框和上传按钮,右浮动*/ #p2{float: right;} #p2 input {width:250px;height: 38px;font-size: 22px;} /*第三层p包住input file*/ #p3{float:left;width:140px;height:38px;position: relative; background: url("upload.jpg") no-repeat 0 0;margin-left: 5px;} #p3 input{position: absolute;width:100%;height: 100%;top:0;left: 0; z-index: 1;opacity:0;} /*图片(选择文件按钮)上的文字*/ .text{display: block;width:140px;height: 38px;position: absolute;top: 0; left:0;text-align: center;line-height: 38px;font-size: 28px; color: orchid;} /*上传按钮的位置*/ .upload{width:70px;height: 38px;background: greenyellow;position: absolute;top:0;right: -75px;} /*鼠标停留在选择文件按钮上的时候切换图片*/ #p3:hover{background: url("upload.jpg") no-repeat 0 -40px;} /*显示图片的p->ul,采用左浮动的方式,一行行的排列图片*/ #show-file{width:760px;height:445px;position: relative;margin:10px auto;overflow: scroll;} #show-file ul{width:760px;height:445px;position: absolute;top:0;left:0;} #show-file ul li{float: left;width:120px;height: 100px;margin: 3px 0 0 3px;position: relative;} /*删除按钮的位置和一些样式*/ #show-file ul li p{display: none;opacity: 0;width:40px;height: 20px;position: absolute;left: 5px;bottom: 5px; background: gold;color: #d32a0e;z-index: 1;cursor: pointer;text-align: center;line-height: 20px;} /*下载按钮的位置和一些样式*/ #show-file ul li span{display: none;opacity: 0;width:40px;height: 20px;position: absolute;right: 5px;bottom: 5px; background: gold;color: #d32a0e;z-index: 1;cursor: pointer;text-align: center;line-height: 20px;} /*把a标签的自带样式去掉,鼠标停留时字体换颜色*/ #show-file ul li span,p a{text-decoration: none;color:orangered;} #show-file ul li span,p a:hover{color: #00fa00;}
jsコード:
<script src="move.js"></script> <script> window.onload = function () { //当选择文件后,会触发这个事件 $('upfile').onchange = function () { $('show').value = this.value;//把获取到的文件伪路径传到编辑框 }; //显示下载按钮 var aLi = $('ul-list').getElementsByTagName('li'); //图片 var aSpan = $('ul-list').getElementsByTagName('span'); //下载按钮 var ap = $('ul-list').getElementsByTagName('p'); //删除按钮 for(var i = 0;i<aLi.length;i++) { aLi[i].index = i; aLi[i].onmousemove = function () { aSpan[this.index].style.display = 'block'; ap[this.index].style.display = 'block'; startMove(ap[this.index],{opacity:100}); //缓冲运动 startMove(aSpan[this.index],{opacity:100}); //缓冲运动 }; aLi[i].onmouseout = function () { aSpan[this.index].style.display = 'none'; ap[this.index].style.display = 'none'; startMove(ap[this.index],{opacity:0}); //缓冲运动 startMove(aSpan[this.index],{opacity:0}); //缓冲运动 } } }; function $(id) { return document.getElementById(id); } </script>
include('myFunctions.php'); if(uploadFile('file','upload')) header("Location:upFileAndDownFile.php");//会马上跳转回原页面,根本感觉不到页面有跳转到这里
include('myFunctions.php'); //获取要下载的文件名(加上路径) $file = $_GET['name']; $rootPath = 'upload/'; downLoadFile($file,$rootPath); 处理删除文件的php文件: $fileName = 'upload/'.$_GET['name']; unlink($fileName); header("Location:upFileAndDownFile.php"); 其中move.js在前面的JS完美运动框架文章有讲过。 myFunctions.php中的函数如下: /** * @function 下载文件 * @param $file 要下载的文件名 * @param $rootPath 文件根路径 * @return 无 */ function downLoadFile($file,$rootPath) { //1.重设响应类型 $info = getimagesize($rootPath.$file); header("Content-Type:".$info['mime']); //2.执行下载的文件名 header("Content-Disposition:attachment;filename=".$file); //3.指定文件大小 header("Content-Length:".filesize($rootPath.$file)); //4.响应内容 readfile($rootPath.$file); } /** * @function 上传文件 * @param $name 表单名 <input type="file" name="pic" /> * @param $path 上传后,文件存放的路径 * @return 返回新的文件路径表示上传成功 false 失败 */ function uploadFile($name,$path) { $file = $_FILES[$name]; //1.过滤上传文件的错误号 if($file['error'] > 0) { //获取错误信息 switch($file['error']) { case 1: $info = '上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。'; break; case 2: $info = '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。'; break; case 3: $info = '文件只有部分被上传。'; break; case 4: $info = '没有文件被上传。'; break; case 6: $info = '找不到临时文件夹'; break; case 7: $info = '文件写入失败。 '; break; } die("上传错误,原因: ".$info); } //2.上传文件大小的过滤 if($file['size'] > 100000000) //字节为单位 die('上传文件大小超出限制!'); //3.上传后的文件名定义 $newfile = null; $fileinfo = pathinfo($file['name']); //解析上传文件名 do{ $newfile = date('YmdHis').".".$fileinfo['extension']; }while(file_exists($path.'/'.$newfile)); //4.执行文件上传 //判断是否是一个上传文件 if(is_uploaded_file($file['tmp_name'])) { //执行文件上传(移动文件到指定目录) if(move_uploaded_file($file['tmp_name'],$path.'/'.$newfile)) return $path.'/'.$newfile; else return false; } else die('不是一个上传文件!'); }
PHP は strace を通じて障害の原因を特定する方法を実装します
PHP は file_get_contents を使用して http リクエストを送信します関数は簡単ですPHP+MySQL の同時実行ロックの高いトランザクション処理の問題解決策
以上がPHPでファイルのアップロード、ダウンロード、削除を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。