php实现下载进度条的方法:1、创建“download.php”文件,代码如“switch ($action) {case 'prepare-download'...}”;2、通过创建js代码显示进度条即可。

本文操作环境:Windows7系统、PHP7.1版、DELL G3电脑
php如何实现下载进度条?
PHP 远程文件下载的进度条实现
download.php
狼群淘客系统基于canphp框架进行开发,MVC结构、数据库碎片式缓存机制,使网站支持更大的负载量,结合淘宝开放平台API实现的一个淘宝客购物导航系统采用php+mysql实现,任何人都可以免费下载使用 。狼群淘客的任何代码都是不加密的,你不用担心会有任何写死的PID,不用担心你的劳动成果被窃取。
立即学习“PHP免费学习笔记(深入)”;
getMessage());
}
return json(compact('tmp_path'));
break;
case 'get-file-size':
// 这里检测下 tmp_path 是否存在
if (file_exists($tmp_path)) {
// 返回 JSON 格式的响应
return json(['size' => filesize($tmp_path)]);
}
break;
default:
# code...
break;
}js
// 咋触发这个函数我就不举例了
function downloadFile() {
var file_size = 0;
var progress = 0;
console.log("Prepared to download");
$.ajax({
url: './download.php?action=prepare-download',
type: 'GET',
dataType: 'json',
beforeSend: function() {
$('#update-button').html(' 正在准备').prop('disabled', 'disabled');
},
})
.done(function(json) {
console.log(json);
file_size = json.file_size;
$('#file-size').html(file_size);
// 显示进度条
console.log("started downloading");
$.ajax({
url: './download.php?action=start-download',
type: 'POST',
dataType: 'json'
})
.done(function(json) {
// set progress to 100 when got the response
progress = 100;
console.log("Downloading finished");
console.log(json);
})
.fail(showAjaxError);
var interval_id = window.setInterval(function() {
$('#imported-progress').html(progress);
$('.progress-bar').css('width', progress+'%').attr('aria-valuenow', progress);
if (progress == 100) {
clearInterval(interval_id);
// 到此远程文件下载完成,继续其他逻辑
} else {
$.ajax({
url: './download.php?action=get-file-size',
type: 'GET'
})
.done(function(json) {
progress = (json.size / file_size * 100).toFixed(2);
updateProgress(progress);
console.log("Progress: "+progress);
})
.fail(showAjaxError);
}
}, 300);
})
.fail(showAjaxError);
}推荐学习:《PHP视频教程》










