php – 导致两个并行加载的东西?
我正在编写一些
PHP,它会进行大量处理,然后生成结果报告.以前它会做一个定期的flush(),但我们正在转向Zend Framework,不能再这样做了.相反,我希望在生成报告时更新某种状态.所以我创建了一个在iframe中加载的进度条,为进度条更新操作和报告生成操作添加了共享内存,并导致输出通过xmlhttprequest加载.一切正常.我的问题是浏览器想要串行而不是并行地执行这两个请求,因此它将请求进度条,然后BLOCK直到进度条完成之前请求实际输出.这意味着该过程永远不会结束,因为真正的工作永远不会开始.
我整个上午都在搜索这个问题并空手而归. 我的下一个操作是将处理分开一些,并使状态更新操作执行实际工作,保存结果,然后使用其他操作转储它.这将是非常痛苦的,我想避免它. 编辑:这是javascript,按要求: function startProgress() { var iFrame = document.createElement('iframe'); document.getElementsByTagName('body')[0].appendChild(iFrame); iFrame.id = 'progressframe'; iFrame.src = '/report/progress'; } function Zend_ProgressBar_Update(data) { document.getElementById('pg-percent').style.width = data.percent + '%'; document.getElementById('pg-text-1').innerHTML = data.text; document.getElementById('pg-text-2').innerHTML = data.text; } function Zend_ProgressBar_Finish() { document.getElementById('pg-percent').style.width = '100%'; document.getElementById('pg-text-1').innerHTML = 'Report Completed'; document.getElementById('pg-text-2').innerHTML = 'Report Completed'; document.getElementById('progressbar').style.display = 'none'; // Hide it } function ajaxTimeout(){ xmlhttp.abort(); alert('Request timed out'); } var xmlhttp; var xmlhttpTimeout; function loadResults(){ if (window.XMLHttpRequest){ // code for IE7+,Firefox,Chrome,Opera,Safari xmlhttp=new XMLHttpRequest(); }else{ // code for IE6,IE5 xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.open("POST","/report/output",true); xmlhttp.onreadystatechange=function(){ if (xmlhttp.readyState == 4 && xmlhttp.status == 200) { clearTimeout(xmlhttpTimeout); document.getElementById('report-output').innerHTML=xmlhttp.responseText; } } var xmlhttpTimeout=setTimeout(ajaxTimeout,600000); // Ten minutes xmlhttp.setRequestHeader('Content-Type','application/x-www-form-urlencoded'); xmlhttp.send('".file_get_contents("php://input")."'); } 这从以下onload脚本调用: onload="startProgress(); setTimeout(loadResults,1000);" 问题不在于Javascript.如果您在其中放置alert(),则会在正确的时间触发警报,但浏览器会延迟第二个http事务,直到第一个完成. 谢谢大家的意见. 在我们的开发计划允许的时间范围内,我没有得到满意的答案.似乎每个常见浏览器都希望在与该站点进行多个事务时重用现有的站点连接.我无法想出任何东西会导致浏览器按需启动并行连接.每当有来自同一服务器的两个请求时,客户端希望以串行方式执行它们. 我最终将处理分成几部分并将其移动到状态栏更新操作中,将报告输出保存到服务器上的临时文件中,然后使状态栏结束功能启动xmlhttprequest以加载结果.输出操作只是吐出临时文件的内容,然后删除它.
使用两个异步ajax可以做到这一点.对于第一个ajax请求,您应该通过调用php-cli在后台深入执行实际工作(因此它不会过期或取消)并返回进程的id(任务)来启动该过程.现在,当您拥有进程ID时,可以启动期刊ajax来显示进程.
制作包含process_id,state,user的db表并不是件坏事.在这种情况下,即使用户在进程运行时关闭浏览器,该过程也会一直持续到完成为止.用户可以重新访问该页面并查看完成的百分比,因为在cli中运行的进程会将进度保存到db表中. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |