向R发出多个Web API请求的信号

时间:2019-11-19 06:40:04

标签: c# asp.net asp.net-web-api signalr

您好,有人可以帮我解决SignalR中的问题吗?我已经创建了一个示例实时数据库,当我更改数据库中的某些数据时遇到了问题,我在API中收到多个请求,可以吗?或它有性能问题。

enter image description here 我收到了来自API的1278请求,我只更改了数据库中数据的一个值。

我的Sql代码

   public IEnumerable<Vehicles> Read(OnChangeEventHandler dependency)
    {
        var list = new List<Vehicles>();

        using (Con)
        {
            Con.Open();
            Cmd.CommandType = CommandType.StoredProcedure;
            Cmd.CommandText = _proc.ReadVehicle;

            Cmd.Notification = null;

            var sqlDependency = new SqlDependency(Cmd);
            sqlDependency.OnChange += new OnChangeEventHandler(dependency);


            if (Con.State == ConnectionState.Closed)
            {
                Con.Open();
            }


            using (var reader = Cmd.ExecuteReader())
            {
                if (reader.HasRows)
                {
                    while (reader.Read())
                    {
                        list.Add(new Vehicles
                        {
                            Id = Convert.ToInt16(reader["Id"]),
                            Car = reader["Car"].ToString(),
                            Brand = reader["Brand"].ToString(),
                            Company = reader["Company"].ToString(),
                            Image = reader["Image"].ToString(),
                            LifeTime = Convert.ToInt16(reader["LifeTime"]),
                            Price = Convert.ToDecimal(reader["Price"]),
                            Type = reader["Type"].ToString(),
                            Year = reader["Year"].ToString()
                        });
                    }
                }
            }
        }

        return list;
    }

这是我的API控制器

    [HttpGet]
    [Route("")]
    public IHttpActionResult Get()
    {
        var list = this._service.ReadVehicles((e, sqlNotif) =>
        {
            if (sqlNotif.Type == SqlNotificationType.Change)
            {
                var hub = new VehicleHub();
                hub.GetVehicles();
            }

        });

        return Ok(list);
    }

我的Signal R集线器

[HubName("VehicleHub")]
public class VehicleHub : Hub
{

    [HubMethodName("getAllVehicles")]
    public void GetVehicles()
    {
        IHubContext context = GlobalHost.ConnectionManager.GetHubContext<VehicleHub>();
        context.Clients.All.getAllVehicles();
    }

}

我的客户端脚本

     $(function () {

         var vehicles = $.connection.VehicleHub;
         vehicles.client.getAllVehicles = function () {
             getVehicles()

        };

         $.connection.hub.start();
         getVehicles()

    });

    function getVehicles() {

        var tbl = $('#carTable');
        $.ajax({
            url: 'http://localhost:62734/api/vehicle',
            contentType: 'application/html ; charset:utf-8',
            type: 'GET',
            dataType: 'json',
            success: function (result) {
                tbl.empty();
                $.each(result, function (key, value) {
                    tbl.append('<tr>' +
                        '<td>' + value.Id + '</td>' +
                        '<td>' + value.Car + '</td>' +
                        '<td>' + value.Brand + '</td>' +
                        '<td>' + value.Type + '</td>' +
                        '</tr>');
                }
                )
            }
        });
    }

1 个答案:

答案 0 :(得分:0)

没关系,它显示多个请求的原因是,它使用长池而不是Web套接字,看起来在本地测试中您尚未在IIS Express中启用Web套接字。

在Web套接字中,一个连接保持打开状态,服务器和客户端都可以定期ping通彼此,以确保两者都已连接。

长轮询以这种方式工作,http连接被打开,客户端等待更新,如果服务器有任何更新,则它将向客户端发送更新,或者最终将其关闭,并允许客户端重新打开连接以确保两者均处于打开状态活。由于在“长轮询”中服务器无法接收来自客户端的ping,因此服务器关闭后,客户端重新打开连接,该连接在逻辑上用作ping以确保两者均已连接。

从Windows功能中,您可以安装对IIS Express的Web套接字支持,并且这些多个连接将被Web套接字替换,并且您不会看到很多请求。