我在我的页面中有这段代码,但是当我在数据库中进行更改时它不会运行,可能是什么问题。 这开始很好,当我加载页面时,它执行两次函数,但是如果我向数据库发送消息,则不执行。
$(function () {
var chat = $.connection.chatHub;
chat.client.allTalks = function () {
refresh();
};
$.connection.hub.start();
refresh();
});
服务器端(中心):
[HubName("chatHub")]
public class ChatHub : Hub
{
public static void AllTalks()
{
IHubContext context = GlobalHost.ConnectionManager.GetHubContext<ChatHub>();
context.Clients.All.allTalks();
}
}
HANDLER
...
using (SqlCommand command = new
SqlCommand(@"SELECT * FROM [dbo].[chat_talks]", connection)) {
// CONTENT
SqlDependency dependency = new SqlDependency(command);
dependency.OnChange += new OnChangeEventHandler(dependency_OnChange);
... }
public void dependency_OnChange(object sender, SqlNotificationEventArgs e)
{
ChatHub.AllTalks();
}
Global.asax中
protected void Application_Start(object sender, EventArgs e)
{
SqlDependency.Start(ConfigurationManager.ConnectionStrings["ProjectSellerConnection"].ConnectionString);
}
答案 0 :(得分:6)
首先,在服务器端代码中使用第一行是多余的。无需在集线器内调用hubContext。你可以这样做:
public static void AllTalks()
{
Clients.All.allTalks();
}
我建议,或许是愚蠢的,不要使用SQL Dependency。我建议使用以下调用SignalR的技术(具体来说,它将调用客户端函数):
var hubContext = GlobalHost.ConnectionManager.GetHubContext<ChatHub>();
hubContext.Clients.All.allTalks();
您可以在MVC和WebAPI控制器中执行此操作,这意味着如果您在这些操作中完成了任何数据库更新,则可以随后使用此方法调用客户端。我知道它不像SQL Dependency那么华丽,也许不是你想要的答案,但它会解决你的问题 - 因为看起来问题似乎是SignalR检测到数据库的变化。
换句话说,这种方法可行,但可能不是你所希望的那种。