Ajax長鏈接和SignalR(刷新客戶端數據)的區別 ajax實現長鏈接

ajax實現長鏈接

 
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" isELIgnored="false" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
    <head>
        <meta http-equiv="pragma" content="no-cache">
        <meta http-equiv="cache-control" content="no-cache">
        <meta http-equiv="expires" content="0">
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <%@ include file="/tags/jquery-lib.jsp"%>
        
        <script type="text/javascript">
            $(function () {
            
                (function longPolling() {
                
                    $.ajax({
                        url: "${pageContext.request.contextPath}/communication/user/ajax.mvc",
                        data: {"timed": new Date().getTime()},
                        dataType: "text",
                        timeout: 5000,
                        error: function (XMLHttpRequest, textStatus, errorThrown) {
                            $("#state").append("[state: " + textStatus + ", error: " + errorThrown + " ]<br/>");
                            if (textStatus == "timeout") { // 請求超時
                                    longPolling(); // 遞歸調用
                                
                                // 其餘錯誤,如網絡錯誤等
                                } else { 
                                    longPolling();
                                }
                            },
                        success: function (data, textStatus) {
                            $("#state").append("[state: " + textStatus + ", data: { " + data + "} ]<br/>");
                            
                            if (textStatus == "success") { // 請求成功
                                longPolling();
                            }
                        }
                    });
                })();
                
            });
        </script>
    </head>
    
    <body>

上面這段代碼就是採用Ajax的方式完成長鏈接,主要優勢就是和服務器始終保持一個鏈接。若是當前鏈接請求成功後,將更新數據而且繼續建立一個新的鏈接和服務器保持聯繫。若是鏈接超時或發生異常,這個時候程序也會建立一個新鏈接繼續請求。這樣就大大節省了服務器和網絡資源,提升了程序的性能,從而也保證了程序的順序。

SignalR 消息推送

關於如何使用SignalR服務推送數據到客戶端在上一篇文章中已經寫了詳細的案例,不瞭解的能夠先去了解SignalR的實現方式。javascript

關於二者的區別(我的看法,不正確的地方請指出):html

Ajax長鏈接:java

Ajax長鏈接是客戶端不停的向服務器發送請求以獲取最新的數據信息。這裏的「不停」實際上是有中止的,只是咱們人眼沒法分辨是否中止,它只是一種快速的停下而後又當即開始鏈接而已。jquery

主要優勢就是和服務器始終保持一個鏈接。若是當前鏈接請求成功後,將更新數據並繼續建立一個新的鏈接和服務器保持聯繫。若是鏈接超時或發生異常,這個時候程序也會建立一個新的鏈接繼續請求,這樣就大大節省了網絡和服務器資源,提升了程序的性能,從而也保證了程序的順序。ajax

SignalR:服務器

不須要客戶端發出請求,服務器只要發現有了新的數據,當即調用客戶端獲取數據的方法,從而實現把新的數據推送到客戶端展現出來。博主百度百科了一下更專業的說法實際上是:網絡

當所鏈接的客戶端變得可用時,服務器代碼能夠當即向其推送內容,而不是讓服務器等待客戶端請求新的數據。mvc

相關文章
相關標籤/搜索