天天看點

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的實作方式。

關于兩者的差別(個人見解,不正确的地方請指出):

Ajax長連接配接:

Ajax長連接配接是用戶端不停的向伺服器發送請求以擷取最新的資料資訊。這裡的“不停”其實是有停止的,隻是我們人眼無法分辨是否停止,它隻是一種快速的停下然後又立即開始連接配接而已。

主要優點就是和伺服器始終保持一個連接配接。如果目前連接配接請求成功後,将更新資料并繼續建立一個新的連接配接和伺服器保持聯系。如果連接配接逾時或發生異常,這個時候程式也會建立一個新的連接配接繼續請求,這樣就大大節省了網絡和伺服器資源,提高了程式的性能,進而也保證了程式的順序。

SignalR:

不需要用戶端送出請求,伺服器隻要發現有了新的資料,立即調用用戶端擷取資料的方法,進而實作把新的資料推送到用戶端展示出來。部落客百度百科了一下更專業的說法其實是:

當所連接配接的用戶端變得可用時,伺服器代碼可以立即向其推送内容,而不是讓伺服器等待用戶端請求新的資料。

關注90後夢想大師,夢想從未止步.

<%@ 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的方式完成長連接配接,主要優點就是和伺服器始終保持一個連接配接。如果目前連接配接請求成功後,将更新資料并且繼續建立一個新的連接配接和伺服器保持聯系。如果連接配接逾時或發生異常,這個時候程式也會建立一個新連接配接繼續請求。這樣就大大節省了伺服器和網絡資源,提高了程式的性能,進而也保證了程式的順序。

      

繼續閱讀