小編給大家分享一下php文件上傳的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括碾子山網(wǎng)站建設(shè)、碾子山網(wǎng)站制作、碾子山網(wǎng)頁(yè)制作以及碾子山網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,碾子山網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到碾子山省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!一、我的準(zhǔn)備情況說明。
編輯器:sublime text3(用什么編輯器看自己愛好)
服務(wù)器構(gòu)建:使用phpstudy2014構(gòu)建服務(wù)器,服務(wù)器文件存儲(chǔ)在我自身電腦D盤的www文件中。(安裝phpstudy會(huì)自動(dòng)生成www文件,安裝在哪個(gè)盤自己做主)。運(yùn)行phpstudy,通過在瀏覽器地址欄輸入localhost可以訪問服務(wù)器中文件。
上傳文件的過程:瀏覽器在客戶端上傳文件,點(diǎn)擊提交,文件被傳送給服務(wù)器中的某個(gè)php文件進(jìn)行處理,該php對(duì)該上傳文件保存到服務(wù)器。
二、創(chuàng)建表單
請(qǐng)看我的html代碼
enctype
在Form元素的語(yǔ)法中,EncType表明提交數(shù)據(jù)的格式 用 Enctype 屬性指定將數(shù)據(jù)回發(fā)到服務(wù)器時(shí)瀏覽器使用的編碼類型。enctype有三種:
1、application/x-www-form-urlencoded: 窗體數(shù)據(jù)被編碼為名稱/值對(duì)。這是標(biāo)準(zhǔn)的編碼格式。
2、multipart/form-data: 窗體數(shù)據(jù)被編碼為一條消息,頁(yè)上的每個(gè)控件對(duì)應(yīng)消息中的一個(gè)部分。
3、 text/plain: 窗體數(shù)據(jù)以純文本形式進(jìn)行編碼,其中不含任何控件或格式字符。
補(bǔ)充(隨便看看就好):orm的enctype屬性為編碼方式,常用有兩種:application/x-www-form-urlencoded和multipart/form-data,默認(rèn)為application/x-www-form-urlencoded。 當(dāng)action為get時(shí)候,瀏覽器用x-www-form-urlencoded的編碼方式把form數(shù)據(jù)轉(zhuǎn)換成一個(gè)字串(name1=value1&name2=value2…),然后把這個(gè)字串a(chǎn)ppend到url后面,用?分割,加載這個(gè)新的url。 當(dāng)action為post時(shí)候,瀏覽器把form數(shù)據(jù)封裝到http body中,然后發(fā)送到server。 如果沒有type=file的控件,用默認(rèn)的application/x-www-form-urlencoded就可以了。 但是如果有type=file的話,就要用到multipart/form-data了。瀏覽器會(huì)把整個(gè)表單以控件為單位分割,并為每個(gè)部分加上Content-Disposition(form-data或者file),Content-Type(默認(rèn)為text/plain),name(控件name)等信息,并加上分割符(boundary)。
有點(diǎn)難理解。
總歸就記住兩句話:如果input標(biāo)簽中有type=file,則enctype=multipart/form-data。如果沒有type=file一般情況下使用application/x-www-form-urlencoded。
文件上傳時(shí)都要將數(shù)據(jù)進(jìn)行一定轉(zhuǎn)化才能上傳到服務(wù)器,application/x-www-form-urlencoded和multipart/form-data兩者之間的區(qū)別就在與轉(zhuǎn)化編碼方式不同。
三、創(chuàng)建php文件用于處理上傳的文件。
上傳文件后效果如下:
每一個(gè)上傳文件都有name、type、size、tmp_name等信息。文件上傳后,這些文件相關(guān)信息存在FILES這個(gè)數(shù)組變量。_FILES[“myfile”][“name”]相當(dāng)于一個(gè)多維數(shù)組的訪問,F(xiàn)ILES先獲取表單名稱為myfile的input上傳的文件數(shù)據(jù),然后再訪問name、type、size、error等數(shù)據(jù)。_FILES["myfile"]["error"]用來(lái)處理文件沒有正常上傳的情況,例如超過限定上傳的文件大小。如果FILES[“myfile”][“error”]=0,表示文件正常上傳。_FILES[“myfile”][“error”]>0表示文件沒有正常上傳。
FILES[“myfile”][“error”]=1上傳文件超過服務(wù)器限定的值,比如超過服務(wù)器空間大小。_FILES[“myfile”][“error”]=2 超過瀏覽器限定上傳的值 $_FILES[“myfile”][“error”]=3文件只有部分被上傳
FILES[“myfile”][“error”]=4沒有文件本上傳。_FILES[“myfile”][“error”]還可以為5、6、7、8,這里不做深究,只需知道其大于0時(shí)就意味這文件上傳出錯(cuò)即可。
上傳限制
通常情況下,服務(wù)器通常會(huì)限制服務(wù)器上傳文件的大小或者類型。我們?cè)谏厦鎝hp代碼的基礎(chǔ)上添加對(duì)上傳文件代碼的限制。
先熟悉幾個(gè)函數(shù)用法:
explode()函數(shù)用于分割字符串,例:explode(“.”,”aaa.HTML”)就是在點(diǎn)的位置將這個(gè)字符串分成”aaa”和”HTML”兩個(gè)字符串,這兩個(gè)字符串按順序存儲(chǔ)在同一個(gè)數(shù)組中。
end()獲取數(shù)組中最后一個(gè)元素的值。
in_array()在數(shù)組中查找某個(gè)元素,看是否存在,存在返回為true,不存在返回為false。
<?php //第一步:明確服務(wù)器規(guī)定上傳至服務(wù)器的文件類型。這里我們只允許上傳以下類型的圖片。 $allowedExts = array("gif", "jpeg", "jpg", "png");// 允許上傳的圖片后綴 //第二部:獲取上傳的文件名稱,通過explorde()函數(shù)將其分割成字符串形式的數(shù)組。 $temp = explode(".", $_FILES["myfile"]["name"]); echo $_FILES["file"]["size"]; $extension = end($temp); // end函數(shù)用于獲取數(shù)組中最后一個(gè)元素的值。 //第三步:列出上傳文件需要滿足的條件 if ((($_FILES["myfile"]["type"] == "image/gif") || ($_FILES["myfile"]["type"] == "image/jpeg") || ($_FILES[myfile"]["type"] == "image/jpg") || ($_FILES["myfile"]["type"] == "image/pjpeg") || ($_FILES["myfile"]["type"] == "image/x-png") || ($_FILES["myfile"]["type"] == "image/png")) && ($_FILES["myfile"]["size"] < 204800) // 小于 200 kb && in_array($extension, $allowedExts)) //in_array表示在$allowedExts數(shù)組中查找$extension這個(gè)字符串 { if ($_FILES["myfile"]["error"] > 0) { echo "錯(cuò)誤:: " . $_FILES["myfile"]["error"] . "<br>"; //舉個(gè)例子服務(wù)器空間不足,文件只能上傳部分就會(huì)出現(xiàn)錯(cuò)誤。 } else { echo "上傳文件名: " . $_FILES["myfile"]["name"] . "<br>"; echo "文件類型: " . $_FILES["myfile"]["type"] . "<br>"; echo "文件大小: " . ($_FILES["myfile"]["size"] / 1024) . " kB<br>"; echo "文件臨時(shí)存儲(chǔ)的位置: " . $_FILES["myfile"]["tmp_name"] . "<br>"; } } else { echo "非法的文件格式"; } ?>
四、保存上傳的文件
文件上傳后,它是保存在一個(gè)臨時(shí)的位置。腳本結(jié)束時(shí)它就會(huì)消失。如果要把他永久的保存在服務(wù)器中,我們要把它保存在另一個(gè)位置。
. file_exists(“upload/” . FILES[“file”][“name”])檢查文件或目錄是否存在。.moveuploadedfile(_FILES["file"]["tmp_name"], "upload/" . $_FILES[“myfile”][“name”]);將上傳文件從臨時(shí)位置轉(zhuǎn)移到服務(wù)器空間。
<?php //第一步:明確服務(wù)器規(guī)定上傳至服務(wù)器的文件類型。這里我們只允許上傳以下類型的圖片。 $allowedExts = array("gif", "jpeg", "jpg", "png");// 允許上傳的圖片后綴 //第二部:獲取上傳的文件名稱,通過explorde()函數(shù)將其分割成字符串形式的數(shù)組。 $temp = explode(".", $_FILES["myfile"]["name"]); echo $_FILES["myfilefile"]["size"]; $extension = end($temp); // end函數(shù)用于獲取數(shù)組中最后一個(gè)元素的值。 //第三步:列出上傳文件需要滿足的 if ((($_FILES["myfile"]["type"] == "image/gif") || ($_FILES["myfile"]["type"] == "image/jpeg") || ($_FILES["myfile"]["type"] == "image/jpg") || ($_FILES["myfile"]["type"] == "image/pjpeg") || ($_FILES["myfile"]["type"] == "image/x-png") || ($_FILES["myfile"]["type"] == "image/png")) && ($_FILES["myfile"]["size"] < 204800) // 小于 200 kb && in_array($extension, $allowedExts))//in_array表示在$allowedExts數(shù)組中查找$extension這個(gè)字符串 { if ($_FILES["myfilefile"]["error"] > 0) { echo "錯(cuò)誤:: " . $_FILES["myfile"]["error"] . "<br>"; } else { echo "上傳文件名: " . $_FILES["myfile"]["name"] . "<br>"; echo "文件類型: " . $_FILES["myfile"]["type"] . "<br>"; echo "文件大小: " . ($_FILES["myfile"]["size"] / 1024) . " kB<br>"; echo "文件臨時(shí)存儲(chǔ)的位置: " . $_FILES["myfile"]["tmp_name"] . "<br>"; // 判斷當(dāng)期目錄(即www文件夾中)下的 upload 目錄(自己創(chuàng)建,名字自?。┦欠翊嬖谠撐募? // 如果沒有 upload 目錄,你需要?jiǎng)?chuàng)建它,upload 目錄權(quán)限為 777 if (file_exists("upload/" . $_FILES["myfile"]["name"])) { echo $_FILES["myfile"]["name"] . " 文件已經(jīng)存在。 "; } else { // 如果 upload 目錄不存在該文件則將文件上傳到 upload 目錄下 move_uploaded_file($_FILES["myfile"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);// echo "文件存儲(chǔ)在: " . "upload/" . $_FILES["myfile"]["name"]; } } } else { echo "非法的文件格式"; } ?>
以上是“php文件上傳的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
文章標(biāo)題:php文件上傳的示例分析-創(chuàng)新互聯(lián)
鏈接分享:http://www.rwnh.cn/article38/dcidsp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、軟件開發(fā)、全網(wǎng)營(yíng)銷推廣、搜索引擎優(yōu)化、企業(yè)網(wǎng)站制作、網(wǎng)站排名
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)