4

これは signalR を使用した最初の試みであり、コードが正しいかどうかわかりません。このコードはテスト用です。signalR は、コントローラー アクションから呼び出されたときにすべてのクライアントに送信する必要があります。

1.NuGetを使用してSignalRをインストールしました(バンドル/縮小にわずかな問題がありました)ので、signalR jsを個別にインポートしています

2.新しいフォルダー SingalR にハブを作成します。

    [HubName("messageHub")]
    public class MessagesHub : Hub
    {
        public void AddMessage(string htmlstring)
        {
            Clients.addMessage(htmlstring);
        }
    }

3.クライアント側のスクリプトを作成しました。サーバー -> クライアントのみが必要で、両方の方法は必要ありません。

<script src="@Url.Content("~/SignalR/jquery.signalR-0.5.2.min.js")" type="text/javascript"></script>
<script src="/signalr/hubs" type="text/javascript"></script>

<div class="content-wrapper">
        <h1 id="lq" class="subtitle">Public Messages</h1>
</div>

<script type="text/javascript">
    $(function () 
    {
        var message = $.connection.messageHub;

        message.addMessage= function (htmlstring) 
        {
            $(htmlstring).insertAfter('#lq');
        };

        $.connection.hub.start();
    });
</script>

4.これは、誰かがアクセスしたときにすべてのクライアントにメッセージを投稿するアクションです。

   public ActionResult Index(int id, string title)
   {
     MessagesModel model = new MessagesModel(id);
     var hubContext = GlobalHost.ConnectionManager.GetHubContext<SignalR.MessagesHub>();
     hubContext.Clients.addMessage("Sample Message");
     return View(model);
   }

Firefox を開くと、firebug でネゴシエートの成功を確認できます。Chrome を開いてこのページのインデックスに移動すると、Firefox のページに挿入された「サンプル メッセージ」が表示されますが、何も起こりません。

更新: Firebug でページから移動すると、「/signalr/hubs」が見つかりません

4

1 に答える 1

4

ばかげているように聞こえるかもしれませんが、問題は、ケーシングが異なっていても同じ名前のクライアントメソッドとサーバーメソッドであったため、次のように変更しました。

[HubName("messageHub")]
    public class MessagesHub : Hub
    {
        public void AddMessage(string htmlstring)
        {
            Clients.addMessage(htmlstring);
        }
    }

に:

  [HubName("messageHub")]
        public class MessagesHub : Hub
        {
            public void SendMessage(string htmlstring)
            {
                Clients.addMessage(htmlstring);
            }
        }
于 2012-06-29T22:25:35.177 に答える