Форум программистов, компьютерный форум, киберфорум
Наши страницы
Schtrich
Войти
Регистрация
Восстановить пароль
Оценить эту запись

Пример использования Long Polling в jQuery & php

Запись от Schtrich размещена 07.12.2012 в 03:13
Обновил(-а) Schtrich 07.12.2012 в 14:34
Метки jquery, long polling, php

Сторона клиента:

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" 
"http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type" />
<script type="text/javascript" 
src="http://code.jquery.com/jquery-1.8.2.min.js"></script>
<script type="text/javascript" charset="utf-8">
 
    var timestap = null;
    
    function WaitForMsg()
    {
        $.ajax({
            
            type: 'GET',
            url: 'comet.php?timestamp='+ timestap,
            async: true,
            cache: false,
            success: function(data){ 
                
                var json = eval('('+ data + ')');
                
                    if (json["msg"]!="")
                    {
                        alert(json["msg"]);
                    }
                    
                    timestap = json["timestamp"];
                    
                    setTimeout('WaitForMsg()',1000);
                
            },
            
            error: function(XMLHttpRequest, textStatus, errorThrown){
                
                // alert("Error: " + textStatus + "(" + errorThrown +")");
                
                setTimeout('WaitForMsg()',15000);
            }
            
        });
    }
    
    $(document).ready(function(){
        
        WaitForMsg();
        
    });
 
</script>
<link type="text/css" rel="stylesheet" href="css/style.css" media="all">
<title>Comet</title>
</head>
<body>
 
</body>
</html>
сторона сервера (comet.php):

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
$filename = dirname(__FILE__)."/data.txt";
 
$lastmodif = isset($_GET['timestamp']) ? $_GET['timestamp'] : 0;
$currentmodif = filemtime($filename);
 
while ($currentmodif <= $lastmodif)
{
    usleep(10000);
    clearstatcache();
    
    $currentmodif =  filemtime($filename);
    
} 
 
$response = array();
 
$response['msg'] = file_get_contents($filename);
$response['timestamp'] = $currentmodif;
 
echo json_encode($response);
При любом изменении файла data.txt в браузере будет выводится сообщение с его содержимым.
Размещено в Без категории
Просмотров 7753 Комментарии 2
Всего комментариев 2
Комментарии
  1. Старый комментарий
    Аватар для Илья Федин
    Вот я пытаюсь сделать чат на файлах, сейчас он на AJAX, хочу перевести на longpolling, но мне надо чтобы при этом можно было как и сейчас редактировать и удалять сообщения. Как мне это сделать? Не подскажите? Вот ссылка: http://185.20.224.232/cr/
    Запись от Илья Федин размещена 23.06.2014 в 08:09 Илья Федин вне форума
  2. Старый комментарий
    Аватар для Илья Федин
    Только если будете пробовать туда писать, не ставьте таймаут на 1, я там намудрил, оставил лишь как шаблон, чтобы заново цифру не писать, когда буду llongpolling делать
    Запись от Илья Федин размещена 23.06.2014 в 08:15 Илья Федин вне форума
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru