谈谈php中上传文件的处理,_PHP教程
谈谈php中上传文件的处理,
这是一个表单的时代。。。
我们在浏览器中编辑自己的信息,会遇到上传头像;在文库中,我们会上传文档......到处存在“上传”这个词。
php是最好的语言(其他语言的程序猿们不要打我...)。php在处理交互方面有天然的优势,自然有强大的函数来处理上传文件。
和提交一般的数据一样,上传文件也需要表单。下面建立一个特殊的表单来上传文件。
<span>1</span> <span><</span><span>form </span><span>enctype</span><span>="multipart/form-data"</span><span> action</span><span>="upload_file.php"</span><span> name</span><span>="upload_form"</span><span> method</span><span>="post"</span><span>></span> <span>2</span> <span><!--</span><span>MAX_FILE_SIZE必须在所有的input之前,以后要是想用上传表单,可以在form之后就写隐藏的input</span><span>--></span> <span>3</span> <span><</span><span>input </span><span>type</span><span>="hidden"</span><span> name</span><span>="MAX_FILE_SIZE"</span><span> value</span><span>="30000"</span><span>/></span> <span>4</span> <span> 上传的文件: </span><span>5</span> <span><</span><span>input </span><span>type</span><span>="file"</span><span> name</span><span>="userfile"</span><span>/></span> <span>6</span> <span><</span><span>hr</span><span>/></span> <span>7</span> <span><</span><span>input </span><span>type</span><span>="submit"</span><span> name</span><span>="sub_button"</span><span> value</span><span>="上传文件的提交按钮"</span><span>/></span> <span>8</span> <span>9</span> <span></</span><span>form</span><span>></span>
ok,我们分析一下这个代码段。
以上的enctype规定了数据在发送给服务器的时候采用什么编码格式。它有三个值:
MAX_FILE_SIZE隐藏字段(单位为字节)必须放在文件输入字段之前,其值为文件的最大尺寸。这是对浏览器的一个建议,php也会检查此项。不过在浏览器端可以绕过这个障碍,因此不要指望用它来阻挡大文件。但是文件最大值受php.ini中的post_max_size= (number)M的限制。但是最好还是加上这个项目,它可以避免用户在花时间等待上传大文件之后才发现大文件上传失败的麻烦。
在用户提交文件表单之后,服务器端就可以接受数据了。PHP中有全局变量$_FILES来处理文件,假设上传字段名称为userfile(可以在字段中随意更改)。
$_FILES['userfile']['name'] 客户端文件的原名称。
$_FILES['userfile']['type'] 文件的MIME类型,这个在PHP端并不检查,因此这个值还不一定有。
$_FILES['userfile']['size'] 上传的文件的大小(单位字节)。
$_FILES['userfile']['tmp_name'] 文件上传后在服务器端存储的临时文件名。
$_FILES['userfile']['error'] 和该文件上传相关的错误代码。如果上传成功,值为0.
文件在上传后,默认存储到服务器默认临时目录中,在php.ini中的upload_tmp_dir设置为其他路径。
在这里还得说说一个move_uploaded_file()函数:
这个函数检查并确保由 file 指定的文件是合法的上传文件(即通过 PHP 的 HTTP POST 上传机制所上传的)。如果文件合法,则将其移动为由 newloc 指定的文件。
如果 file 不是合法的上传文件,不会出现任何操作,move_uploaded_file() 将返回 false。
如果 file 是合法的上传文件,但出于某些原因无法移动,不会出现任何操作,move_uploaded_file() 将返回 false,此外还会发出一条警告。
这种检查显得格外重要,如果上传的文件有可能会造成对用户或本系统的其他用户显示其内容的话。
下面是一个php上传文件实例:
<span> 1</span> <span><</span><span>b</span><span>></span>上传文件处理<span></</span><span>b</span><span>></span> <span> 2</span> <span><</span><span>hr</span><span>/></span> <span> 3</span> <span><?</span><span>php </span><span> 4</span> <span>if (isset($_FILES['userfile'])) { </span><span> 5</span> <span> $uploaddir = 'upload/'; </span><span> 6</span> <span> $uploadfile = $uploaddir . basename($_FILES['userfile']['name']); </span><span> 7</span> <span> echo '<pre class="brush:php;toolbar:false">'; </span><span> 8</span> <span> if (move_uploaded_file($_FILES['userfile']['tmp_name'], $uploadfile)) { </span><span> 9</span> <span> echo '上传文件成功'.'<br>'; </span><span>10</span> <span> } else { </span><span>11</span> <span> echo '上传文件失败'.'<br>'; </span><span>12</span> <span> } </span><span>13</span> <span> echo '这是上传文件的一些信息:' . '<br>'; </span><span>14</span> <span> print_r($_FILES); </span><span>15</span> <span> echo '<pre class="brush:php;toolbar:false">'; </span><span>16</span> <span> die(); </span><span>17</span> <span>} </span><span>18</span> <span>19</span> <span>?></span> <span>20</span> <span><</span><span>b</span><span>></span>上传表单<span></</span><span>b</span><span>></span> <span>21</span> <span><!--</span><span>表单中的enctype属,必须和以下定义保持一致</span><span>--></span> <span>22</span> <span><</span><span>form </span><span>enctype</span><span>="multipart/form-data"</span><span> action</span><span>="upload_file.php"</span><span> name</span><span>="upload_form"</span><span> method</span><span>="post"</span><span>></span> <span>23</span> <span><!--</span><span>MAX_FILE_SIZE必须在所有的input之前,以后要是想用上传表单,可以在form之后就写隐藏的input</span><span>--></span> <span>24</span> <span><</span><span>input </span><span>type</span><span>="hidden"</span><span> name</span><span>="MAX_FILE_SIZE"</span><span> value</span><span>="30000"</span><span>/></span> <span>25</span> <span> 上传的文件: </span><span>26</span> <span><</span><span>input </span><span>type</span><span>="file"</span><span> name</span><span>="userfile"</span><span>/></span> <span>27</span> <span><</span><span>hr</span><span>/></span> <span>28</span> <span><</span><span>input </span><span>type</span><span>="submit"</span><span> name</span><span>="sub_button"</span><span> value</span><span>="上传文件的提交按钮"</span><span>/></span> <span>29</span> <span></</span><span>form</span><span>><br /></span>

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。
