我在here问了一个问题,已经回答并正常工作,
但我的问题是,当脚本运行超过4~5秒时,所有ajax
个请求在完成运行脚本之前根本不起作用。
事实上,我使用进度复制文件,当我选择大文件时,30%处理ajax
无法获得进度百分比。
如果你查看我的问题,你会理解我所说的。
Copy.php
$f = mysql_query(" select * from `process` ");
$f = mysql_fetch_assoc($f);
$total_bytes_readed = $f['total-bytes-readed'];
$total_bytes = $f['total-bytes'];
$abort = $f['state'] == 'abort'?true:false;
$remote = fopen($src, 'r');
$local = fopen($des, 'w');
$filesize = filesize($src);
$d = strtotime(date('Y-m-d H:i:s'));
$B = $speed = $time_remaining = $read_bytes = 0;
while(!feof($remote) && !$abort) {
$field = mysql_query(" select * from `process` ");
$field = mysql_fetch_assoc($field);
if($field['state']=='abort')
{
fclose($remote);
fclose($local);
if(file_exists($des))
unlink($des);
$abort = true;
return;
}else{
$bitrate = 2048*2048;
$buffer = fread($remote, $bitrate);
fwrite($local, $buffer);
$read_bytes += $bitrate ;
$total_bytes_readed += $bitrate;
$D = strtotime(date('Y-m-d H:i:s'));
if($D-$d >=1)
{
$d = $D;
$speed = $read_bytes - $B;
$B = $read_bytes;
$total_bytes_remaining = $total_bytes - $total_bytes_readed;
$time_remaining = $total_bytes_remaining/$speed;
}
mysql_query("UPDATE `process` SET
`total-bytes-readed` = '$total_bytes_readed',
`speed` = '$speed',
`time-remaining` = '$time_remaining'
WHERE `process`.`id` =1");
}
}
fclose($remote);
fclose($local);
mysql_query("UPDATE `process` SET
`total-bytes-readed` = '$total_bytes_readed',
`speed` = '$speed',
`time-remaining` = '$time_remaining'
WHERE `process`.`id` =1");
progress.php
if(isset($_POST['cancel']) && $_POST['cancel']==1)
mysql_query("UPDATE `process` SET `state` = 'abort' WHERE `process`.`id` =1");
$f = mysql_query(" select * from `process` ");
$f = mysql_fetch_assoc($f);
$re = array('totalfiles' => $f['total-files'],
'totalbytes' => $f['total-bytes'],
'bytesreaded' => $f['total-bytes-readed'],
'file' => $f['file'],
'from' => $f['from'],
'to' => $f['to'],
'speed' => ByteToSize($f['speed'])."/Second",
'time' => seconds_to_time($f['time-remaining']),
'items' => $f['items-remaining'],
'state' => $f['state'],
);
echo json_encode($re);
JS
setInterval(function(){
$.post( progress.php,{cancel:cancel_val},
function(data){
//...
});
},300);
答案 0 :(得分:0)
在没有看到它的情况下,我猜想问题是你有多个重叠的ajax请求。
您应该在ajax调用的success函数中设置setInterval
,而不是使用setTimeout
。这样就可以确保最多只能同时存在1个ajax请求。
所以你的javascript会是这样的:
function updateProgress() {
$.post( progress.php,{cancel:cancel_val},
function(data){
//...
setTimeout(updateProgress, 300);
});
};
updateProgress();