ASP.NET MVC 迅速集成 SignalR

在现代 Web 应用程序中,实时更新数据是一个常见需求。本文将详细介绍如何在 ASP.NET MVC 项目中使用 SignalR 实现定时任务操作数据库并将数据更新到网页。我们将逐步讲解如何配置 SignalR、创建定时任务、操作数据库以及在前端显示实时数据。

目录

  1. 项目初始化
  2. 安装和配置 SignalR
  3. 创建数据库和模型
  4. 创建 SignalR Hub
  5. 实现定时任务
  6. 前端页面和脚本
  7. 运行和测试

1. 项目初始化

首先,创建一个新的 ASP.NET MVC 项目。

● 打开 Visual Studio,选择 File > New > Project。

● 选择 ASP.NET Web Application,命名项目为 RealTimeDataUpdate。

● 选择 MVC 模板并点击 Create。

2. 安装和配置 SignalR

在项目中安装 SignalR 包,并进行配置。

  • .打开 NuGet 包管理器控制台,运行以下命令:
bash 复制代码
Install-Package Microsoft.AspNet.SignalR
  • .在 Startup.cs 文件中配置 SignalR:
csharp 复制代码
using Microsoft.Owin;
using Owin;

[assembly: OwinStartup(typeof(RealTimeDataUpdate.Startup))]
namespace RealTimeDataUpdate
{
    public class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            app.MapSignalR();
        }
    }
}

3. 创建数据库和模型

创建一个简单的数据库和模型来存储和获取数据。

1. 创建一个名为 DataContext 的类:
csharp 复制代码
using System.Data.Entity;

public class DataContext : DbContext
{
    public DbSet<SensorData> SensorData { get; set; }
}

public class SensorData
{
    public int Id { get; set; }
    public string Temperature { get; set; }
    public string Humidity { get; set; }
    public DateTime Timestamp { get; set; }
}

2. 在 Web.config 文件中添加数据库连接字符串:

csharp 复制代码
<connectionStrings>
    <add name="DataContext" connectionString="Data Source=(localdb)\MSSQLLocalDB;Initial Catalog=RealTimeData;Integrated Security=True" providerName="System.Data.SqlClient" />
</connectionStrings>

4. 创建 SignalR Hub

创建一个 SignalR Hub 来处理客户端连接和数据更新。

1. 创建一个名为 DataHub 的类:

csharp 复制代码
using Microsoft.AspNet.SignalR;

public class DataHub : Hub
{
    public void SendData(string temperature, string humidity)
    {
        Clients.All.updateData(new { Temperature = temperature, Humidity = humidity, Timestamp = DateTime.Now });
    }
}

5. 实现定时任务

使用 System.Threading.Timer 实现定时任务,每隔一段时间从数据库获取数据并通过 SignalR 更新到客户端。

1. 创建一个名为 DataScheduler 的类:

csharp 复制代码
using System;
using System.Threading;

public class DataScheduler
{
    private Timer _timer;

    public void Start()
    {
        _timer = new Timer(UpdateData, null, 0, 5000); // 每5秒执行一次
    }

    private void UpdateData(object state)
    {
        using (var context = new DataContext())
        {
            var latestData = context.SensorData.OrderByDescending(d => d.Timestamp).FirstOrDefault();
            if (latestData != null)
            {
                var hubContext = GlobalHost.ConnectionManager.GetHubContext<DataHub>();
                hubContext.Clients.All.updateData(new
                {
                    Temperature = latestData.Temperature,
                    Humidity = latestData.Humidity,
                    Timestamp = latestData.Timestamp
                });
            }
        }
    }
}

2. 在 Global.asax 文件中启动定时任务:

csharp 复制代码
protected void Application_Start()
{
    AreaRegistration.RegisterAllAreas();
    FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    RouteConfig.RegisterRoutes(RouteTable.Routes);
    BundleConfig.RegisterBundles(BundleTable.Bundles);

    var scheduler = new DataScheduler();
    scheduler.Start();
}

6. 前端页面和脚本

创建一个简单的前端页面来显示实时数据。

1. 在 Views/Home/Index.cshtml 文件中添加以下代码:

html 复制代码
@model IEnumerable<RealTimeDataUpdate.Models.SensorData>

@{
    ViewBag.Title = "实时数据监测";
}

<h2>最新温湿度数据</h2>

<table>
    <tr>
        <th>Temperature</th>

        <th>Humidity</th>

        <th>Timestamp</th>

    </tr>

    <tr>
        <td id="temperature"></td>

        <td id="humidity"></td>

        <td id="timestamp"></td>

    </tr>

</table>

<script src="~/Scripts/jquery-3.6.0.min.js"></script>

<script src="~/Scripts/jquery.signalR-2.4.2.min.js"></script>

<script src="~/signalr/hubs"></script>

<script type="text/javascript">
    $(document).ready(function() {
        var hub = $.connection.dataHub;
        hub.client.updateData = function (data) {
            $('#temperature').text(data.Temperature);
            $('#humidity').text(data.Humidity);
            $('#timestamp').text(data.Timestamp);
        };
        $.connection.hub.start().done(function () {
            console.log("SignalR connected");
        });
    });
</script>

7. 运行和测试

  • 运行项目,确保数据库已创建并有一些初始数据。
  • 打开浏览器,访问你的应用程序,应该可以看到实时更新的温湿度数据。

通过以上步骤,你已经成功在 ASP.NET MVC 项目中使用 SignalR 实现了定时任务操作数据库并实时更新网页数据。

相关推荐
leeyi几秒前
Multi-Agent:让多个 AI 分工协作完成复杂任务
后端·aigc·agent
长栎2 分钟前
你的策略模式是 Map<String, Strategy>?那不过是最廉价的 if-else 替代品
后端
长栎8 分钟前
你写的 abstract class 里全是钩子方法——模板模式不是让你填空,是让你别越界
后端
ping某12 分钟前
语法树,到底是一棵什么形状的树?
后端
_柳青杨17 分钟前
一文吃透 Node.js 事件循环:从原理到 Node 20+ 重大变更
javascript·后端
Alson_Code33 分钟前
人机协作项目文档--HITL-AgentScope
后端·aigc·ai编程
IT_陈寒44 分钟前
Java 并行流把我坑惨了,这6小时加班值了
前端·人工智能·后端
葫芦和十三2 小时前
图解 MongoDB 03|CRUD 全链路:一条 find 怎么穿过 WiredTiger
后端·mongodb·agent
葫芦和十三9 小时前
图解 MongoDB 04|索引模型:每建一个索引,就是在 B+-tree 森林里多栽一棵
后端·mongodb·agent
用户479492835691511 小时前
claude Fable用不了?把Gpt 5.5pro接到你的claude code里
前端·后端