實時數據顯示--SignalR實例演示

来源:http://www.cnblogs.com/insus/archive/2016/07/01/5619422.html
-Advertisement-
Play Games

近段時間,有實現一個看板的功能,就是用戶更新信息時,即是對資料庫的數據進行插入,更新,或是刪除時,在牆上的屏幕的數據不需要人為去刷新,用戶就能看到更新後的數據。實現此功能,Insus.NET使用SignalR的技術來實現。下麵的實例中,雖然不是實際的數據,但是實現過程是一樣的,現在分享給大家學習學習 ...


近段時間,有實現一個看板的功能,就是用戶更新信息時,即是對資料庫的數據進行插入,更新,或是刪除時,在牆上的屏幕的數據不需要人為去刷新,用戶就能看到更新後的數據。

實現此功能,Insus.NET使用SignalR的技術來實現。下麵的實例中,雖然不是實際的數據,但是實現過程是一樣的,現在分享給大家學習學習......


在項目中安裝SignalR:

 

上圖中,把綠色對鉤的組件均選擇安裝。

安裝完成,你看到一個readme.txt文件:

 

此你應該知道它在說什麼。看了,在App_Start目錄中,創建一個類,類名為Startup:

 

 

接下來,我們需要在Global.asax.cs的Application_Start和Application_End方法中,添加下麵高亮的2行代碼:

 

當然你的Web.config的配置文件中,還得添加真正的MS SQL Server連接語句。

 TableB model:

 

現在,在項目錄中,創建一個SignalR目錄,我們就可以在這個目錄中添加Hub類了:

 

所有客戶端使用的方法名,均使用駝峰寫法,小寫開頭。

現在,我們需要實現去資料庫獲取數據,當資料庫的數據變化時,客戶端也能實時顯示:



上圖中的藍色箭頭的Hub的方法,即是再前一張圖中的Show方法(#17行代碼)。另外有關SqlDependency類,可以查閱MSDN的網站。

 在MVC的項目的控制器中,我們創建2個Action操作:

 

創建視圖,參考下麵的步驟:



上面#3和#4是一樣。在ASP.NET MVC 4.0之後,可以使用~/signalr/js,不過在新版的.NET是,使用#3的寫法還是行的。

另外引用js的順序有講究。先引用jQuery,再引用SignalR的,再引用#3或#4。

上面標記#6的js代碼,參考下麵:


 上面標記#7的樣式代碼:

 table {
            border-collapse: collapse;
            border: solid #999;
            border-width: 1px 0 0 1px;
        }

            table caption {
                font-size: 14px;
                font-weight: bolder;
            }

            table th, table td {
                border: solid #999;
                border-width: 0 1px 1px 0;
                padding: 2px;
            }

        tfoot td {
            text-align: center;
        }
Source Code

 

下麵是實時演示,Insus.NET有使用幾個瀏覽器Edge,IE,Firefox,Chrome,併在資料庫進行添加記錄,修改數據和刪除數據,所有客戶端均能實時顯示:


 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.下載安裝VMware,我安裝的是VMware 12.VMware從11開始不再支持32位系統,32位系統請安裝10. VMware官方功能特性介紹http://www.vmware.com/cn/products/workstation VMware下載安裝。地址:http://www.epin ...
  • 1、使用yum安裝 yum -y install httpd mysql mysql-server php php-mysql postgresql postgresql-server php-postgresql php-pgsql php-devel 2、配置httpd 2.1、啟動httpd服 ...
  • 互斥量和臨界區非常相似,只有擁有了互斥對象的線程才可以訪問共用資源,而互斥對象只有一個,因此可以保證同一時刻有且僅有一個線程可以訪問共用資源,達到線程同步的目的。 互斥量相對於臨界區更為高級,可以對互斥量進行命名,支持跨進程的線程同步。互斥量是調用的Win32的API對互斥鎖的操作,因此在同一操作系 ...
  • ...
  • 來源:威客百科 本文地址:baike.renwuyi.com/2015-04/9181.html 轉載請註明出處。 ...
  • 1、進入支付寶首頁 GET https://auth.alipay.com/login/index.htm HTTP/1.1Accept: */*Accept-Language: zh-CNAccept-Encoding: gzip, deflateUser-Agent: Mozilla/4.0 ( ...
  • 很早之前看到過RESTful Web Services,並未在意,也沒找相關資料進行學習。今天偶爾有一機會,就找了點資料進行研究,發現RESTful真是“簡約而不簡單”。下麵用示例來說明: 1 項目結構 2 REST 服務介面定義 3 REST服務介面實現 4 將服務HOST 5 打開瀏覽器,即可進 ...
  • 一. 結構體的傳遞 Cpp代碼 #define JNAAPI extern "C" __declspec(dllexport) // C方式導出函數 typedef struct { int osVersion; int majorVersion; int minorVersion; int bui ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...