2010-05-26 55 views
1

我正在创建文件上传进度条。我有一个复制数据的CGI脚本,在这里,我在某些迭代之后将进度条值增加1。我将增加的值存储在XML文件中(我也尝试使用纯文本文件)。另一方面,我有一个Ajax读取从XML增加值,并根据它增加DIV元素。Ajax从XML读取更新值

但是,这里发生的是,在我看来,虽然ajax读取所有递增的值,但它在CGI完成执行后处理它。一旦文件复制和CGI中的其他内容完成,就是进度条开始执行。我的代码是:

AJAX:::: 

function polling_start() { //GETS CALLED WHEN USER HITS FILE UPLOAD BUTTON 
     intervalID = window.setInterval(send_request,100); 
} 
window.onload = function(){ 
     request = initXMLHttpClient(); 
     request.overrideMimeType('text/xml'); 
     progress = document.getElementById('progress'); 
} 

function initXMLHttpClient() { 
     if (window.XMLHttpRequest){ 
     // code for IE7+, Firefox, Chrome, Opera, Safari 
     xmlhttp = new XMLHttpRequest(); 
     } 
     else{ 
     // code for IE6, IE5 
     xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); 
     } 
return xmlhttp 
} 

function send_request() 
{ 
request.open("GET","progress_bar.xml",true); 
request.onreadystatechange = request_handler; 
request.send(); 
} 

function request_handler() 
{ 
     if (request.readyState == 4 && request.status == 200) 
     { 
     var level=request.responseXML.getElementsByTagName('PROGRESS')[0].firstChild; 
     progress.style.width = progress.innerHTML = level.nodeValue + '%'; 
     progress.style.backgroundColor = "green"; 
     } 
} 

/*************ON SERVER SIDE********************/ 

     char xmlDat1[] = "<DOCUMENT><PROGRESS>"; 
     char xmlDat2[] = "</PROGRESS></DOCUMENT>"; 

fptr = fopen("progress_bar.xml", "w"); 

.........OTHER STUFF.............................. 
................................. 
       if(i == inc && j<=100) 
       { 
       fprintf(fptr, "%s\n", "<?xml version=\"1.0\"?>\n<!DOCTYPE DOCUMENT [\n<!ELEMENT DOCUMENT (PROGRESS)>\n<!ELEMENT PROGRESS (#PCDATA)>\n]>"); 
       //fprintf(fptr, "%s\n", "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\"\n\"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">"); 
       fprintf(fptr, "%s", xmlDat1); // 
       fprintf(fptr, "%d" ,j); 
       fprintf(fptr, "%s" ,xmlDat2); 
       fseek(fptr, 0, SEEK_SET); 
       /*fprintf(fptr, "%d" ,j); 
       fseek(fptr, 0, SEEK_SET);*/ 
       i = 0; 
       //sleep(1); 
       j++; 
       } 

(我也试过的.text写,但相同的响应)

任何快速响应将是可观的。

回答

0

只需在此添加:文件写入完成后(1至100个值写入进度条增量),text/xml文件中的数据不可用。 我的客户端包括Ajax工作正常,只有问题是 request.readyState == 4只有在所有数据写入文本文件后才会发生。 因此,我需要一种方法,让我的更新数据可以被ajax同时读取。

谢谢

+0

每当你写入新的状态时冲洗并关闭文件。你在整个循环中都将它打开。 – 2010-05-27 00:11:50

+0

谢谢你的回应....但我试过,但同样的回应......我尝试使用文本文件.....尝试叉().....但没有成功,直到现在: - ( – Punit 2010-05-27 00:29:44