Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/opencv/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Signalr 无法向信号器中的组发送消息_Signalr - Fatal编程技术网

Signalr 无法向信号器中的组发送消息

Signalr 无法向信号器中的组发送消息,signalr,Signalr,我正在使用信号器库。我正在运行我的应用程序的3个实例,然后我将两个用户添加到名为“Test”的组中。现在,当我向“测试”组发送消息时,消息根本没有被传递 public class ChatHub : Hub { public void send(string name, string message) { //This line of code is not working Clients.Group("te

我正在使用信号器库。我正在运行我的应用程序的3个实例,然后我将两个用户添加到名为“Test”的组中。现在,当我向“测试”组发送消息时,消息根本没有被传递

public class ChatHub : Hub
    {
        public void send(string name, string message)
        {
            //This line of code is not working
            Clients.Group("test").broadcastMessage(message);


            //This is working
            //Clients.All.broadcastMessage(name, message);

        }

        public void JoinGroup(string groupName)
        {
            Groups.Add(this.Context.ConnectionId, groupName);

        }

        public void RemoveGroup(string groupName)
        {
            Groups.Remove(this.Context.ConnectionId, groupName);
        }
    }
//客户端

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>SignalR Simple Chat</title>
    <style type="text/css">
        .container {
            background-color: #99CCFF;
            border: thick solid #808080;
            padding: 20px;
            margin: 20px;
        }
    </style>
</head>
<body>
    <div class="container">

        <input type="text" id="groupName" />
        <input type="button" id="joinGroup" value="Join" />
        <br />
        <input type="text" id="message" />
        <input type="button" id="sendmessage" value="Send" />
        <input type="hidden" id="displayname" />
        <ul id="discussion">
        </ul>
    </div>
    <script type="text/javascript" src="Scripts/jquery-1.6.4.min.js"></script>
    <script type="text/javascript" src="Scripts/j`enter code here`query.signalR-1.0.0-rc1.js"></script>

    <script type="text/javascript" src="/signalr/hubs"></script>



</body>

<script type="text/javascript">

    $(function () {
        // Declare a proxy to reference the hub.  
        var chat = $.connection.chatHub;
        // Create a function that the hub can call to broadcast messages. 
        chat.client.broadcastMessage = function (name, message) {
            // Html encode display name and message.  
            var encodedName = $('<div />').text(name).html();
            var encodedMsg = $('<div />').text(message).html();
            // Add the message to the page.  
            $('#discussion').append('<li><strong>' + encodedName
                + '</strong>:&nbsp;&nbsp;' + encodedMsg + '</li>');
        };
        // Get the user name and store it to prepend to messages. 
        $('#displayname').val(prompt('Enter your name:', ''));
        // Set initial focus to message input box.   
        $('#message').focus();
        // Start the connection. 
        $.connection.hub.start().done(function () {
            $('#sendmessage').click(function () {
                // Call the Send method on the hub.  
                chat.server.send($('#displayname').val(), $('#message').val());
                // Clear text box and reset focus for next comment.  
                $('#message').val('').focus();
            });


            $('#joinGroup').click(function () {
                // Call the Send method on the hub.  
                chat.server.joinGroup($('#groupName').val());
            });
        });
    });

</script>

</html>

信号员简单聊天
.集装箱{
背景色:#99CCFF;
边框:厚实线#808080;
填充:20px;
利润率:20px;
}

$(函数(){ //声明代理以引用中心。 var chat=$.connection.chatHub; //创建一个中心可以调用以广播消息的函数。 chat.client.broadcastMessage=函数(名称、消息){ //Html编码显示名称和消息。 var encodedName=$('').text(name).html(); var encodedMsg=$('').text(message.html(); //将消息添加到页面。 $(“#讨论”)。追加(“
  • ”+encodedName +“:”+encodedMsg+”
  • ); }; //获取用户名并将其存储到消息前。 $('#displayname').val(提示('输入您的姓名:',''); //将初始焦点设置为消息输入框。 $(“#消息”).focus(); //启动连接。 $.connection.hub.start().done(函数(){ $('#sendmessage')。单击(函数(){ //在集线器上调用Send方法。 chat.server.send($('#displayname').val(),$('#message').val()); //清除文本框并重置下一条注释的焦点。 $('#message').val('.focus(); }); $('#joinGroup')。单击(函数(){ //在集线器上调用Send方法。 chat.server.joinGroup($('#groupName').val()); }); }); });
    实际上,客户端上的'broadcastMessage'需要两个参数,而我在使用group调用'broadcastMessage'时只传递了一个参数

    改变

    'Clients.Group("test").broadcastMessage(message);'
    
     to 
    
    'Clients.Group("test").broadcastMessage(name, message);' worked.
    

    实际上,客户端上的'broadcastMessage'需要两个参数,而我在使用group调用'broadcastMessage'时只传递了一个参数

    改变

    'Clients.Group("test").broadcastMessage(message);'
    
     to 
    
    'Clients.Group("test").broadcastMessage(name, message);' worked.
    

    将此答案标记为答案。将此答案标记为答案。