PHP的APC模塊實(shí)現(xiàn)上傳進(jìn)度條
APC模塊,它的全稱是Alternative PHP Cache。APC可以將所有PHP代碼會被緩存起來, 另外它可提供一定的內(nèi)存緩存功能.但是這個功能并不是十分完美,有報告說如果頻繁使用APC緩存的寫入功能,會導(dǎo)致不可預(yù)料的錯誤.如果想使用這個功能,可以看看apc_fetch,apc_store等幾個與apc緩存相關(guān)的函數(shù)。
值得高興的是從5.2開始APC加入了APC_UPLOAD_PROGRESS,解決了困擾大家已久的進(jìn)度條問題。并且它把原來的上傳時把臨時文件全部緩存到內(nèi)存改成了當(dāng)臨時文件達(dá)到設(shè)定值時就自動保存到硬盤,有效地改善了內(nèi)存利用狀況。
它的作用原理是在上傳時候賦予每個上傳一個唯一的ID,當(dāng)PHP 腳本收到一個上傳文件時,解釋程序?qū)⒆詣訖z查$_POST數(shù)組中名為APC_UPLOAD_PROGRESS 的隱藏字段,它將成為緩存變量,存儲關(guān)于上傳的信息,這樣腳本就可以通過上傳的ID來訪問上傳文件的狀態(tài)信息。
<!–以下為上傳表單–> <form enctype="multipart/form-data" id="upload_form" action="" method="POST"> <input type="hidden" name="APC_UPLOAD_PROGRESS" id="progress_key" value="upid"/> 視頻標(biāo)題:<input type="text" id="subject" name="subject"/> 視頻說明:<input type="text" id="content" name="content"/> 視頻TAG(以逗號分割)<input type="text" id="tag" name="tags"/> <input type="file" id="upfile" name="upfile"/> <input type="submit" id="filesubmit" value="上傳" onclick="startProgress(‘upid'); return true;"/> <!–注意:startProgress(‘upid')中的參數(shù)是你從php中分配的唯一上傳參數(shù)–> </form> <!–以下為上傳進(jìn)度條–> <div id="upstatus" style="width: 500px; height: 30px; border: 1px solid ##ffffde; color:#796140;"> </div <div id="progressouter" style="width: 500px; height: 20px; border: 3px solid #de7e00; display:none;"> <div id="progressinner" style="position: relative; height: 20px; color:#796140; background-color: #f6d095; width: 0%; "></div> </div>
最主要的就是那個APC_UPLOAD_PROGRESS的隱藏域,有了它腳本才能去訪問目前上傳文件的狀態(tài),另外加一個顯示上傳狀態(tài)的div就好了。
下面是處理Ajax的腳本,用了Jquery框架,json傳遞消息。
function getProgress(upid){ var url = "<{$siteurl}>epadmin/upprocess"; $.getJSON( url, { progress_key: upid }, function(json){ $("#progressinner").width(json.per+"%"); $("#upstatus").html(‘文件大小:'+json.total+‘KB'+‘ 已上傳:'+json.current+‘KB'); if (json.per < 100){ setTimeout(function(){ getProgress(upid); }, 10); }else{ $("#upstatus").html("視頻上傳完成,正在處理數(shù)據(jù),請稍后……"); } } ) } function startProgress(upid){ $("#progressouter").css({ display:"block" }); setTimeout(function(){ getProgress(upid); }, 100); }
再下來就是讀取上傳狀態(tài)的PHP代碼了,至于上傳文件的處理可以按照平常自己的來寫。
//上傳文件操作函數(shù),可按照自己的需要編寫
function upflvAction() { if($_SERVER['REQUEST_METHOD']==‘POST'){ $subject = trim($this->f->filter($this->_request->getPost(‘subject'))); $content = trim($this->f->filter($this->_request->getPost(‘content'))); Zend_Loader::loadClass(‘Custom_FlvOp'); $flv = new Custom_FlvOp; $flv->uploadFlv(‘upfile',$subject,$content); } } //這就是讀取上傳狀態(tài)的函數(shù)了~~ function upprocessAction() { if(isset($_GET['progress_key'])) { $status = apc_fetch(‘upload_'.$_GET['progress_key']); $json = array( ‘per'=>$status['current']/$status['total']*100, ‘total'=>round($status['total']/1024), ‘current'=>round($status['current']/1024), ); require_once("Zend/Json.php"); echo Zend_Json::encode($json); } }
好了,現(xiàn)在就可以將其部署自己的站點(diǎn)中了,自己看看效果是不是很酷?
以上就是PHP的APC模塊制作上傳進(jìn)度條的關(guān)鍵點(diǎn)介紹,希望對大家的學(xué)習(xí)有所啟發(fā),對大家有所幫助。
- php ajax實(shí)現(xiàn)文件上傳進(jìn)度條
- PHP+apc+ajax實(shí)現(xiàn)的ajax_upload上傳進(jìn)度條代碼
- php實(shí)現(xiàn)簡單的上傳進(jìn)度條
- php使用APC實(shí)現(xiàn)實(shí)時上傳進(jìn)度條功能
- PHP設(shè)置進(jìn)度條的方法
- PHP中使用Session配合Javascript實(shí)現(xiàn)文件上傳進(jìn)度條功能
- php+ajax實(shí)現(xiàn)帶進(jìn)度條的大數(shù)據(jù)排隊(duì)導(dǎo)出思路以及源碼
- ajax+php打造進(jìn)度條 readyState各狀態(tài)
- php 進(jìn)度條實(shí)現(xiàn)代碼
- PHP 文件上傳進(jìn)度條的兩種實(shí)現(xiàn)方法的代碼
- PHP+FLASH實(shí)現(xiàn)上傳文件進(jìn)度條相關(guān)文件 下載
- PHP實(shí)現(xiàn)的進(jìn)度條效果詳解
相關(guān)文章
利用curl抓取遠(yuǎn)程頁面內(nèi)容的示例代碼
利用curl抓取遠(yuǎn)程頁面內(nèi)容的一個小示例,需要的朋友可以過來參考下2013-07-07PHP獲取日期對應(yīng)星期、一周日期、星期開始與結(jié)束日期的方法
這篇文章主要介紹了PHP獲取日期對應(yīng)星期、一周日期、星期開始與結(jié)束日期的方法,涉及php日期與時間相關(guān)計(jì)算操作技巧,需要的朋友可以參考下2018-06-06php session_start()出錯原因分析及解決方法
本文是對php中session_start()的出錯原因及解決方法進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-10-10PHP實(shí)現(xiàn)生成數(shù)據(jù)字典功能示例
這篇文章主要介紹了PHP實(shí)現(xiàn)生成數(shù)據(jù)字典功能,涉及php針對mysql常見的連接、數(shù)據(jù)表查詢、遍歷、table表格構(gòu)成等相關(guān)操作技巧,需要的朋友可以參考下2018-05-05PHP利用遞歸函數(shù)實(shí)現(xiàn)無限級分類的方法
今天小編就為大家分享一篇關(guān)于PHP利用遞歸函數(shù)實(shí)現(xiàn)無限級分類的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03