国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

php多個文件上傳圖片上傳實例

2024-09-04 11:44:36
字體:
來源:轉載
供稿:網友

多個文件上傳和單獨文件上傳的處理方式是一樣的,只需要在客戶端多提供幾個類型為“file”的輸入表單,并指定不同的“name”屬性值,例如,在下面的代碼中,可以讓用戶同時選擇三個本地文件一起上傳給服務器,客戶端的表單如下所示:

  1. <html> 
  2. <head><title>多個文件上傳表單</title></head> 
  3. <body> 
  4. <form action="mul_upload.php" method="post" enctype="multipart/form-data"
  5. <input type="hidden" name="MAX_FILE_SIZE" value="1000000"
  6. 選擇文件1:<input type="file" name='myfile[]'><br> 
  7. 選擇文件2:<input type="file" name='myfile[]'><br> 
  8. 選擇文件3:<input type="file" name='myfile[]'><br> 
  9. <input type="submit" value="上傳文件"
  10. </form> 
  11. </body> 
  12. </html> 

在上面的代碼中,將三個文件類型的表單以數組的形式組織在一起,當上面的表單教給PHP的腳本文件mul_upload.php時,在服務器端同樣使用全局數組$_FILES存儲所有上述文件的信息,但$_FILES由二維數組已經轉變為三維數組,這樣就可以存儲多個上傳文件的信息,在腳本文件mul_upload.php中,使用print_r()函數將$_FILES數組中的內容輸出,代碼如下所示:

  1. <?php 
  2. //打印三維數組$_FILES中的內容,查看一下存儲上傳文件的結構 
  3. print_r($_FILES); 
  4. ?> 

當選擇三個本地文件提交后,輸出結果如下所示:

  1. Array( 
  2.     [myfile]=>Array( 
  3.         [name]=>Array(---$_FILES["myfile"]["name"]存儲所有上傳文件的內容 
  4.             [0]=>Rav.ini---$_FILES["myfile"]["name"][0]第一個上傳文件的名稱 
  5.             [1]=>msgsocm.log---$_FILES["myfile"]["name"][1]第二個上傳文件的名稱 
  6.             [2]=>NOTEPAD.EXE)---$_FILES["myfile"]["name"][2]第三個上傳文件的名稱 
  7.         [type]=>Array(---$_FILES["myfile"]["type"]存儲所有上傳文件的類型 
  8.             [0]=>application/octet-stream---$_FILES["myfile"]["type"][0]第一個上傳文件的類型 
  9.             [1]=>application/octet-stream---$_FILES["myfile"]["type"][1]第二個上傳文件的類型 
  10.             [2]=>application/octet-stream)---$_FILES["myfile"]["type"][2]第三個上傳文件的類型 
  11.         [tmp_name]=>Array( //開源軟件:Vevb.com 
  12.             [0]=>C:/WINDOWS/Temp/phpAF.tmp 
  13.             [1]=>C:/WINDOWS/Temp/phpB0.tmp 
  14.             [2]=>C:/WINDOWS/Temp/phpB1.tmp) 
  15.         [error]=>Array( 
  16.             [0]=>0 
  17.             [1]=>0 
  18.             [2]=>0) 
  19.         [size]=>Array( 
  20.             [0]=>64 
  21.             [1]=>1350 
  22.             [2]=>66560)) 

通過輸出$_FILES數組的值可以看到,處理多個文件的上傳和單個文件上傳時的情況一樣的,只是$_FILES數組的結構形式略有不同,通過這種方式可以支持更多數量的文件上傳.

例子代碼如下:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  2. <html xmlns="http://www.w3.org/1999/xhtml">  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />  
  5. <title>文檔上傳</title>  
  6. </head>  
  7. <body>  
  8. <script language="javascript"><!--  
  9. 動態添加文件選擇控件-->  
  10. function AddRow()  
  11. {  
  12. var eNewRow = tblData.insertRow();  
  13. for (var i=0;i<1;i++)  
  14. {  
  15. var eNewCell = eNewRow.insertCell();  
  16. eNewCell.innerHTML = "<tr><td><input type='file' name='filelist[]' size='50'/></td></tr>";  
  17. }  
  18. }  
  19. // --></script>  
  20. <form name="myform" method="post" action="uploadfile.php" enctype="multipart/form-data" >  
  21. <table id="tblData" width="400" border="0">  
  22. <!-- 將上傳文件必須用post的方法和enctype="multipart/form-data" -->  
  23. <!-- 將本頁的網址傳給uploadfile.php-->  
  24. <input name="postadd" type="hidden" value="<?php echo "http://".$_SERVER['HTTP_HOST'].$_SERVER["PHP_SELF"]; ?>" />  
  25. <tr><td>文件上傳列表  
  26. <input type="button" name="addfile" onclick="AddRow()" value="添加列表" /></td></tr>  
  27. <!-- filelist[]必須是一個數組-->  
  28. <tr><td><input type="file" name="filelist[]" size="50" /></td></tr>  
  29. </table>  
  30. <input type="submit" name="submitfile" value="提交文件" />  
  31. </form>  
  32. </body>  
  33. </html>  
  34. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  35. <html xmlns="http://www.w3.org/1999/xhtml">  
  36. <head>  
  37. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />  
  38. <title>文檔上傳</title>  
  39. </head>  
  40. <body>  
  41. <script language="javascript"><!--  
  42. 動態添加文件選擇控件-->  
  43. function AddRow()  
  44. {  
  45. var eNewRow = tblData.insertRow();  
  46. for (var i=0;i<1;i++)  
  47. {  
  48. var eNewCell = eNewRow.insertCell();  
  49. eNewCell.innerHTML = "<tr><td><input type='file' name='filelist[]' size='50'/></td></tr>";  
  50. }  
  51. // --></script>  
  52. <form name="myform" method="post" action="uploadfile.php" enctype="multipart/form-data" >  
  53. <table id="tblData" width="400" border="0">  
  54. <!-- 將上傳文件必須用post的方法和enctype="multipart/form-data" -->  
  55. <!-- 將本頁的網址傳給uploadfile.php-->  
  56. <input name="postadd" type="hidden" value="<?php echo "http://".$_SERVER['HTTP_HOST'].$_SERVER["PHP_SELF"]; ?>" />  
  57. <tr><td>文件上傳列表  
  58. <input type="button" name="addfile" onclick="AddRow()" value="添加列表" /></td></tr>  
  59. <!-- filelist[]必須是一個數組-->  
  60. <tr><td><input type="file" name="filelist[]" size="50" /></td></tr>  
  61. </table>  
  62. <input type="submit" name="submitfile" value="提交文件" />  
  63. </form>  
  64. </body>  
  65. </html>  

提交文件代碼:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  2. <html xmlns="http://www.w3.org/1999/xhtml">  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />  
  5. <title>文件上傳結果</title>  
  6. </head>  
  7. <body>  
  8. <?php  
  9. if ($_POST["submitfile"]!="")  
  10. {  
  11. $Path="./".date('Ym')."/";  
  12. if (!is_dir($Path))//創建路徑  
  13. mkdir($Path); }  
  14. echo "<div>";  
  15. for ($i=0;$i<count($filelist);$i++)  
  16. //$_FILES["filelist"]["size"][$i]的排列順序不可以變,因為fileist是一個二維數組  
  17. if ($_FILES["filelist"]["size"][$i]!=0)  
  18. {  
  19. $File=$Path.date('Ymdhm')."_".$_FILES["filelist"]["name"][$i];  
  20. if (move_uploaded_file($_FILES["filelist"]["tmp_name"][$i],$File))  
  21. echo "文件上傳成功 文件類型:".$_FILES["filelist"]["type"][$i]." "."文件名:"  
  22. .$_FILES["filelist"]["name"][$i]."<br>"; }  
  23. else  
  24. echo "文件名:".$_FILES["filelist"]["name"][$i]."上傳失敗</br>"; }  
  25. }  
  26. }  
  27. echo "</div><br><a href="$postadd" href="$postadd">返回</a></div>";  
  28. }  
  29. ?>  
  30. </body>  
  31. </html> 

上面例子基于 js來動態增加上傳文件框了,從而達到多文件上傳的功能.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 通榆县| 浦东新区| 通榆县| 临洮县| 乐至县| 渭南市| 乐山市| 莱芜市| 吐鲁番市| 扎鲁特旗| 社旗县| 体育| 商水县| 新乡市| 汾阳市| 通城县| 理塘县| 广昌县| 万山特区| 通榆县| 来安县| 香港| 美姑县| 黄山市| 七台河市| 马公市| 林西县| 桃园县| 高淳县| 香河县| 钟山县| 青阳县| 台湾省| 鄂伦春自治旗| 故城县| 眉山市| 红安县| 海丰县| 屏边| 宁安市| 皋兰县|