SignalR不调用jQuery函数

时间:2014-03-14 14:48:08

标签: c# javascript jquery asp.net signalr

我在我的页面中有这段代码,但是当我在数据库中进行更改时它不会运行,可能是什么问题。 这开始很好,当我加载页面时,它执行两次函数,但是如果我向数据库发送消息,则不执行。

 

$(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);
        }

enter image description here

1 个答案:

答案 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检测到数据库的变化。

换句话说,这种方法可行,但可能不是你所希望的那种。