您好,有人可以帮我解决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>');
}
)
}
});
}
答案 0 :(得分:0)
没关系,它显示多个请求的原因是,它使用长池而不是Web套接字,看起来在本地测试中您尚未在IIS Express中启用Web套接字。
在Web套接字中,一个连接保持打开状态,服务器和客户端都可以定期ping通彼此,以确保两者都已连接。
长轮询以这种方式工作,http连接被打开,客户端等待更新,如果服务器有任何更新,则它将向客户端发送更新,或者最终将其关闭,并允许客户端重新打开连接以确保两者均处于打开状态活。由于在“长轮询”中服务器无法接收来自客户端的ping,因此服务器关闭后,客户端重新打开连接,该连接在逻辑上用作ping以确保两者均已连接。
从Windows功能中,您可以安装对IIS Express的Web套接字支持,并且这些多个连接将被Web套接字替换,并且您不会看到很多请求。