当前位置:   article > 正文

php做上传进度条,PHP配合apc实现上传进度条

php配合apc

PHP配合apc实现上传进度条PHP配合apc实现上传进度条, 一直以为PHP是无法做到进度条一个动态的功能,原来还是自己的知识面不够,看到了apc扩展相关的一些文章,利用apc扩展达到了动态实现效果。根据找到相关的文章自己并在此基础上做了一些小修改。自己的服务器用的window,在这里主要针对的是window上的应用。

1.服务器要支持apc扩展,没有此扩展的话,百度一下php_apc.dll ,下载一个扩展扩展要求php.5.2以上。

2.配置apc相关配置,重启apachePHP Code复制内容到剪贴板

extension=php_apc.dll

apc.rfc1867 = on

apc.max_file_size = 1000M

upload_max_filesize = 1000M

post_max_size = 1000M

说明一下:至于参数要配多大,得看项目需要apc.max_file_size, 设置apc所支持上传文件的大小,要求apc.max_file_size <=upload_max_filesize 并且apc.max_file_size <=post_max_size.重新启动apache即可实现apc的支持.

3.在代码里面利用phpinfo();查看apc扩展安装了没有。

4.下面是实现代码:

getprogress.phpPHP Code复制内容到剪贴板

session_start();

if(isset($_GET['progress_key'])) {

$status = apc_fetch('upload_'.$_GET['progress_key']);

echo ($status['current']/$status['total'])*100;

}

?>

upload.phpPHP Code复制内容到剪贴板

$id = $_GET['id'];

?>

"multipart/form-data" id="upload_form" action="target.php"

method="POST">

"hidden" name="APC_UPLOAD_PROGRESS"

id="progress_key" value=""/>

"file" id="test_file" name="test_file"/>

"window.parent.startProgress(); return true;"

type="submit" value="上传"/>

target.phpPHP Code复制内容到剪贴板

set_time_limit(600);

if($_SERVER['REQUEST_METHOD']=='POST') {

move_uploaded_file($_FILES"test_file",

dirname($_SERVER['SCRIPT_FILENAME'])."/UploadTemp/" .

$_FILES"test_file");//UploadTemp文件夹位于此脚本相同目录下

echo "上传成功";

}

?>

index.phpPHP Code复制内容到剪贴板

$id = md5(uniqid(rand(), true));

?>

"js/jquery-1.4.4.min.js" language="javascript">

"javascript">

var proNum=0;

var loop=0;

var progressResult;

function sendURL() {

$.ajax({

type : 'GET',

url : "getprogress.php?progress_key=",

async : true,

cache : false,

dataType : 'json',

data: "progress_key=",

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);

}

"theframe" name="theframe"

src="upload.php?id="

style="border: none; height: 100px; width: 400px;" >

"progressouter" style="width: 500px; height: 20px; border: 6px solid red;

display:none;">

"progressinner" style="position: relative; height: 20px; background-color:

purple; width: 0%; ">

'showNum'>

'showNum2'>

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/249436
推荐阅读
相关标签
  

闽ICP备14008679号