php阻塞长轮询,php – 长轮询锁定其他AJAX调用

我希望进行长时间轮询以将某些数据“推送”到客户端,并且我还在与长轮询并行的情况下对服务器进行其他无关的AJAX调用.在长轮询收到响应(来自响应或超时)之前,我的其他AJAX调用似乎无法完成.当我单步执行Javascript时,似乎第二个AJAX请求是在适当的时间发送的,但是在长轮询请求得到响应之前没有收到响应.知道发生了什么事吗?

以下是长轮询部分的代码:

服务器端:

function getPlaylistTracksIfChanged($playlist_id,$numClientTracks) {

$reportChange = false;

for($i = 0; $i < 10; $i++) {

$numServerTracks = $this->PlaylistTrack->find('count',array(

'conditions' => array('playlist_id' => $playlist_id)

)

);

if($numClientTracks != $numServerTracks) {

$reportChange = true;

break;

}

sleep(3);

}

if($reportChange) {

$playlist_tracks = $this->PlaylistTrack->find('all',array(

'conditions' => array('playlist_id' => $playlist_id),'order' => array('PlaylistTrack.position')

)

);

$this->set('playlist_tracks',$playlist_tracks);

$this->layout = false;

$this->render('show_playlist_tracks_list');

} else {

$this->autoRender = false;

return 'false';

}

}

客户端:

function checkForChangesOnServer() {

$.post('/getResultsIfChanged/' + playlist_id + '/' + $('#sortable_tracks').children().size(),function(results) {

if(results == 'false') {

//alert('no change');

} else {

//alert('change');

}

checkForPlaylistChangesOnServer();

});

}

以及另一个AJAX调用的示例:

服务器端:

function getLibraryTracksStartingWithLetter($user_id,$letter) {

$results = $this->Track->find(

'all',array(

'conditions' => array(

'user_id' => $user_id,'OR' => array(

'Track.artist LIKE' => $letter . '%','Track.name LIKE' => $letter . '%'

)

),'order' => array('case when Track.artist = "" then 1 else 0 end','Track.artist','Track.name')

)

);

$this->set('results',$results);

$this->layout = false;

$this->render('show_library_results_list');

}

客户端:

function loadLibraryResultsForLetter(letter) {

highlightLetterFilter(letter);

$.post('/getLibraryTracksStartingWithLetter/' + user_id + '/' + letter,function(results) {

updateLibraryResults(results);

});

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值