php使用APC實現(xiàn)實時上傳進度條功能
php不具備實時上傳進度條功能,如果想有這種功能我們一般會使用ajax來實現(xiàn),但是php提供了一個apc,它就可以與php配置實現(xiàn)上傳進度條功能。
主要針對的是window上的應用。
1.服務器要支持apc擴展,沒有此擴展的話,下載一個擴展擴展要求php.5.2以上。
2.配置apc相關配置,重啟apache
代碼如下
extension=php_apc.dll
apc.rfc1867 = on
apc.max_file_size = 1000M
upload_max_filesize = 1000M
post_max_size = 1000M
說明一下:至于參數(shù)要配多大,得看項目需要apc.max_file_size, 設置apc所支持上傳文件的大小,要求apc.max_file_size<=upload_max_filesize 并且apc.max_file_size <=post_max_size.重新啟動apache即可實現(xiàn)apc的支持.
3.在代碼里面利用phpinfo();查看apc擴展安裝了沒有。
4.下面是實現(xiàn)代碼:
getprogress.php
代碼如下
<?php
session_start();
if(isset($_GET['progress_key'])) {
$status = apc_fetch('upload_'.$_GET['progress_key']);
echo ($status['current']/$status['total'])*100;
}
?>
upload.php
PHP Code
<?php
$id = $_GET['id'];
?>
<form enctype="multipart/form-data" id="upload_form" action="target.php" method="POST">
<input type="hidden" name="APC_UPLOAD_PROGRESS"
id="progress_key" value="<?php echo $id?>"/>
<input type="file" id="test_file" name="test_file"/><br/>
<input onclick="window.parent.startProgress(); return true;"
type="submit" value="上傳"/>
</form>
target.php
代碼如下
<?php
set_time_limit(600);
if($_SERVER['REQUEST_METHOD']=='POST') {
move_uploaded_file($_FILES["test_file"]["tmp_name"],
dirname($_SERVER['SCRIPT_FILENAME'])."/UploadTemp/" . $_FILES["test_file"]["name"]);//UploadTemp文件夾位于此腳本相同目錄下
echo "<p>上傳成功</p>";
}
?>
index.php
代碼如下
<?php
$id = md5(uniqid(rand(), true));
?>
<html>
<head><title>上傳進度</title></head>
<body>
<script src="js/jquery-1.4.4.min.js" language="javascript"></script>
<script language="javascript">
var proNum=0;
var loop=0;
var progressResult;
function sendURL() {
$.ajax({
type : 'GET',
url : "getprogress.php?progress_key=<?php echo $id;?>",
async : true,
cache : false,
dataType : 'json',
data: "progress_key=<?php echo $id;?>",
success : function(e) {
progressResult = e;
proNum=parseInt(progressResult);
document.getElementById("progressinner").style.width = proNum+"%";
document.getElementById("showNum").innerHTML = proNum+"%";
if ( proNum < 100){
setTimeout("getProgress()", 100);
}
}
});
}
function getProgress(){
loop++;
sendURL();
}
var interval;
function startProgress(){
document.getElementById("progressouter").style.display="block";
setTimeout("getProgress()", 100);
}
</script>
<iframe id="theframe" name="theframe"
src="upload.php?id=<?php echo $id; ?>"
style="border: none; height: 100px; width: 400px;" >
</iframe>
<br/><br/>
<div id="progressouter" style="width: 500px; height: 20px; border: 6px solid red; display:none;">
<div id="progressinner" style="position: relative; height: 20px; background-color: purple; width: 0%; "></div>
</div>
<div id='showNum'></div><br>
<div id='showNum2'></div>
</body>
</html>
以上就是跟大家分享的php使用APC實現(xiàn)實時上傳進度條功能的方法,希望對大家的學習有所幫助。
- php ajax實現(xiàn)文件上傳進度條
- PHP+apc+ajax實現(xiàn)的ajax_upload上傳進度條代碼
- php實現(xiàn)簡單的上傳進度條
- PHP的APC模塊實現(xiàn)上傳進度條
- PHP設置進度條的方法
- PHP中使用Session配合Javascript實現(xiàn)文件上傳進度條功能
- php+ajax實現(xiàn)帶進度條的大數(shù)據(jù)排隊導出思路以及源碼
- ajax+php打造進度條 readyState各狀態(tài)
- php 進度條實現(xiàn)代碼
- PHP 文件上傳進度條的兩種實現(xiàn)方法的代碼
- PHP+FLASH實現(xiàn)上傳文件進度條相關文件 下載
- PHP實現(xiàn)的進度條效果詳解
相關文章
php+js iframe實現(xiàn)上傳頭像界面無跳轉(zhuǎn)
這篇文章主要介紹了php+js實現(xiàn)的上傳頭像界面無跳轉(zhuǎn),示例中用到了iframe,需要的朋友可以參考下2014-04-04
PHP中include和require的區(qū)別實例分析
網(wǎng)上太多關于PHP中include與require區(qū)別。然而事實真的如此嗎,今天我們就通過一個具體的實例來簡單分析驗證下2017-05-05

