開源的PHP+mysql:第10講時間函數(shù)和文件上傳.ppt_第1頁
開源的PHP+mysql:第10講時間函數(shù)和文件上傳.ppt_第2頁
開源的PHP+mysql:第10講時間函數(shù)和文件上傳.ppt_第3頁
開源的PHP+mysql:第10講時間函數(shù)和文件上傳.ppt_第4頁
開源的PHP+mysql:第10講時間函數(shù)和文件上傳.ppt_第5頁
已閱讀5頁,還剩16頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

1、第10講 日期函數(shù)和文件上傳(12、15章),課前回顧,窗體處理與URL參數(shù)(重點) 網(wǎng)頁窗體的用途 HTML標(biāo)簽建立網(wǎng)頁窗體 $_POST與$_GET結(jié)合數(shù)組變量 URL參數(shù)傳遞數(shù)據(jù) 常用Html標(biāo)簽(掌握) 文本框,密碼框,文本區(qū)域框 單選框,多選框,下拉框,本節(jié)內(nèi)容,日期和時間函數(shù) 常用的日期和時間函數(shù) 處理日期和時間 文件上傳 文件上傳的相關(guān)函數(shù) 文件上傳示例,10.1.1日期和時間函數(shù),函數(shù):string date ( string format , int timestamp ) 說明:返回將整數(shù) timestamp 按照給定的格式字串而產(chǎn)生的字符串。如果沒有給出時間戳則使用本地當(dāng)

2、前時間。參閱教材201頁查看此函數(shù)的格式化參數(shù)內(nèi)容,10.1.1日期和時間函數(shù),函數(shù):array getdate ( int timestamp ) 說明:返回一個根據(jù) timestamp 得出的包含有日期信息的結(jié)合數(shù)組。如果沒有給出時間戳則認(rèn)為是當(dāng)前本地時間。 ,10.1.2 處理時間,函數(shù):int mktime ( int hour , int minute , int second , int month , int day , int year ) 說明:根據(jù)給出的參數(shù)返回 Unix 時間戳(January 1 1970 00:00:00 GMT)。 ,10.1.2 處理時間,函數(shù):i

3、nt time () 說明:返回自從 Unix 紀(jì)元(格林威治時間 1970 年 1 月 1 日 00:00:00)到當(dāng)前時間的秒數(shù)。 ,10.1.2 處理時間,函數(shù): int strtotime ( string time , int now ) 說明:將任何英文文本的日期時間描述解析為 Unix 時間戳。 ,10.2 文件上傳,在B/S程序中文件上傳已經(jīng)成為一個常用功能。其目的是客戶可以通過瀏覽器(Browser)將文件上傳到服務(wù)器(Server)上的指定目錄。 PHP中文件上傳的基礎(chǔ)知識 表單提交 對文件的操作,10.2.1 表頭要求, 文件上傳 上傳文件:提交: ,10.2.1注意幾個

4、特征屬性,POST方法: 表單最常用的功能,向目標(biāo)頁面?zhèn)鬟f變量,我們在上傳文件的時候,會在表單中設(shè)置相應(yīng)的屬性,來完成文件的傳遞 enctype=multipart/form-data 這樣服務(wù)器就會知道,我們要傳遞一個文件,這樣服務(wù)器可以知道上載的文件帶有常規(guī)的表單信息。 MAX_FILE_SIZE 此字段必須在文件輸入字段之前,控制最大的傳遞文件的大小(字節(jié)) 真的可以控制嗎? 設(shè)置瀏覽器文件輸入瀏覽按鈕,10.2.1注意幾個特征屬性,MAX_FILE_SIZE的值只是對瀏覽器的一個建議,實際上可以被簡單的攻擊,我們不要對瀏覽器端的限制寄予什么希望,它只能避免君子的錯誤輸入,對于普通的we

5、b工程師都會跳過瀏覽器端的限制。 但是最好還是在表單上使用MAX_FILE_SIZE,因為對于善意的錯誤我們可以幫助糾正,避免用戶花費很長的時間等待大文件上傳,傳了半天,才發(fā)現(xiàn)無法上傳。 我們在服務(wù)器端的php.ini中設(shè)置對表單傳遞的數(shù)據(jù)進一步判斷 file_uploads = On /Off 是否允許文件上傳 upload_max_filesize = 2M 上傳的文件的最大大小 post_max_size = 8M POST數(shù)據(jù)所允許的最大大小 表單傳遞的數(shù)據(jù),文件只是其中的一部分,所以設(shè)置時,upload_max_filesize應(yīng)該小于post_max_size,10.2.2超級全局

6、數(shù)組$_FILES,PHP程序中,需要處理的上傳數(shù)據(jù)保存在全局?jǐn)?shù)組$_FILES(超級全局?jǐn)?shù)組)中 保存$_FILES數(shù)組中的元素,將HTML表單的type=file標(biāo)記的名稱name=userfile 存放在數(shù)組中。 1:存儲在$_FILESuserfilename中的值是: 客戶端文件系統(tǒng)的文件的名稱 2:存儲在$_FILESuserfiletype中的值是: 客戶端傳遞的文件的類型,10.2.2超級全局?jǐn)?shù)組$_FILES,3:存儲在$_FILESuserfilesize中的值是: 文件的字節(jié)的大小 4:存儲在$_FILESuserfiletmp_name中的值 文件被上傳后在服務(wù)器存儲的

7、臨時全路徑 5:存儲在$_FILESuserfileerror中的值是: 文件上傳的錯誤代碼,10.2.2錯誤代碼代表的含義,在$_FILESuserfileerror中返回的錯誤代碼是在PHP4.2.0版本中引入的。具體如下: 值為0:表示沒有發(fā)生任何錯誤。 值為1:表示上傳文件的大小超出了約定值。文件大小的最大值是在PHP配置文件中指定的,該指令是:upload_max_filesize。 值為2:表示上傳文件大小超出了HTML表單隱藏域?qū)傩缘腗AXFILESIZE元素所指定的最大值。 值為3:表示文件只被部分上傳。 值為4:表示沒有上傳任何文件。,10.2.3 臨時存放目錄,上傳的文件被

8、放置到服務(wù)器端臨時目錄:/tmp目錄里面命名為一個唯一的,隨機生成的臨時文件名。注:該文件在程序執(zhí)行完后將自動被刪除掉。在刪除前可以像本地文件一樣操作。 /tmp目錄是默認(rèn)的上傳臨時文件存放地點,如果需要更改這個目錄:可以編輯php.ini 文件File Uploads 段的upload_tmp_dir 屬性值。,10.2.4 上傳后的處理,使用is_uploaded_file( )函數(shù)來檢查此文件是否是上傳文件。 應(yīng)該使用move_uploaded_file(臨時路徑/臨時文件名,目的路徑/目的文件名 ) 函數(shù)將存放在臨時目錄下的上傳文件拷貝出來,存放到指定目錄的指定文件名,如果目標(biāo)存在將會

9、被覆蓋。,10.2.4 處理頁面代碼,if ($_FILESuserfileerror 0) echo 上傳錯誤: ; switch ($_FILESuserfileerror) case 1: echo 上傳文件大小超出了PHP配置文件中的約定值:upload_max_filesize; break; case 2: echo 上傳文件大小超出了表單中的約定值: max_file_size; break;,10.2.4 處理頁面代碼,case 3: echo 文件只被部分上載; break; case 4: echo 沒有上傳任何文件; break; exit; ,if ($_FILESuserfiletype != text/plain) echo 問題: 文件不是一個文本文件。; exit; $upfile = ./uploads/.$_FILESuserfilename;,10.2.4 處理頁面代碼,if (is_uploaded_file($_FILESuserfiletmp_name) /判斷是否為上傳文件 if (!move_uploaded_file($_FILESu

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論