私はあまりにもずっと前に何か類似したことをしました。 JSONオブジェクトとしてテキストファイルに進捗状況を記録する関数を書いた。その後、jQueryの要求に応じてJSONオブジェクトをブラウザに返すPHP関数を作成しました。
私のPHPコードは次のようになります。
function logProgress($task, $status, $progress) {
$basedir = "/var/www/" . SITE_ROOT . "/";
$log_file = $basedir . "logs/progress.log";
$logFileContent = file_get_contents($mrp_log_file);
if($logFileContent){
$logFileArray = json_decode($logFileContent, TRUE);
} else {
$logFileArray = array();
}
$logFileArray[$task]=array('task'=>$task,'status'=>$status,'progress'=>$progress);
$logFile = fopen($log_file, 'w+') or error_log("Failed to open progress file $mrp_log_file for writing");
fwrite($logFile, json_encode($logFileArray));
fclose($logFile);
}
データを取得するには、このように簡単です:jQueryのから
function readProgressLog() {
//Returns a JSON object stored in the progress log.
$basedir = "/var/www/" . SITE_ROOT . "/";
$log_file = $basedir . "logs/progress.log";
$logFileContents = file_get_contents($log_file);
return $logFileContents;
}
、次の2つのAJAX呼び出しになるだろう、 1つはプロセスを開始し、もう1つはテキストファイルをポーリングします。
function updateProgress() {
var data = {
action:'getProgressUpdate'};
var settings = {success: function(json){
var done = false;
if(json!=null) {
//Put your code to update the progress bar here.
//I look for a JSON property called Done to flag the process as completed.
if(json.Done==null) {
var t2 = setTimeout("updateProgress()", 1000);
} else {
clearTimeout(t2);
done = true;
clearProgressLog();
}
} else {
var t2 = setTimeout("updateProgress()", 1000);
}
},
data:data,
cache:false,
type: 'POST',
dataType:"json"};
$.ajax('/ajax/polling.ajax.php', settings);
}
私が気づいたことの一つは、そうでない場合は、あなたのポーリング、あなたはポーリングAJAX呼び出しは、あなたのプロセスのAJAX呼び出しとは異なるPHPファイルを使用して確認してくださいということです:ポーリング呼び出しのための私のjavascriptは、このようになりますコールはプロセスコールが終了するまで終了しません。
私のこの回答を見て、あなたを助けてください:http://stackoverflow.com/questions/9062078/asychronous-php/9062164#9062164 – xbonez
あなたはどのような情報の例を挙げることができますか?処理? –
私たちにお知らせいただきありがとうございます。私はあなたが探しているものを見つけることを願っています! –