1

誰かが私が理解するのを手伝ってくれますか

次のコードの何が問題になっていますか?SignalRを使用してサーバーメソッドからクライアントメソッドが呼び出されていません。

ブロードキャストボタンがクリックされたときにクライアントメソッドを呼び出すことができます。また、コンソールアプリケーションからselfInvokeコードを実行すると、イベントが発生します。

サーバークラスは、別のアセンブリのCustomEventハンドラーにあります。

チャットハブのコードは次のとおりです。

namespace MySample.Handler
{
    [HubName("chat")] 
    public class Chat: Hub
    {
        public void Send(string message)
        {
            Clients.addMessage(message);
            // I tried this code as well:
            // IHubContext context = GlobalHost.ConnectionManager.GetHubContext<Chat>();
           // context.Clients.addMessage("Hello world");
        }
    }
}

チャットハブを呼び出すためのソースコードは次のとおりです。

namespace MySample.Handler
{
    public static class SelfInvoke
    {
        public static void OnEvent()
        {
            var hubConnection = new HubConnection("http://localhost:48994");
            var chat = hubConnection.CreateProxy("chat");
            hubConnection.Start().Wait();
            string message1 = "Hai from OnEvent Handler!!!";
            chat.Invoke("Send", message1).Wait();
        }
    }
}

Index.aspx

    <script src="Scripts/jquery-1.6.4.min.js" type="text/javascript"></script>
    <script src="Scripts/jquery.signalR-0.5.2.min.js" type="text/javascript"></script>
    <script src="/signalr/hubs" type="text/javascript"></script>
    <script type="text/javascript">
        $(function () {
          var chat = $.connection.chat;

          chat.addMessage = function (message) {
              $('#messages').append('<li>' + message + '</li>');
          };

          $("#broadcast").click(function () {
              chat.send($('#msg').val());
          });
          $.connection.hub.start();
        });
    </script>
  <input type="text" id="msg" />
  <input type="button" id="broadcast" value="broadcast" />
  <ul id="messages">
  </ul>

index.aspx.cs[コードの背後にあるコード..]

   protected void Page_Load(object sender, EventArgs e)
   {
        SelfInvoke.OnEvent();
   }

どんな助けでも大歓迎です。

よろしくヴィンス

4

1 に答える 1

0

JavaScriptクライアント関数の定義を次のように変更します。

chat.client.XXX = function ...

それ以外の:

chat.XXX = function ...

また、サーバーへの呼び出しを次のように変更します。

chat.server.send($('#msg').val());

それ以外の:

chat.send($('#msg').val());

于 2013-01-08T21:34:40.817 に答える