使用SignalR流式传输数据

本文关键字:传输 数据 SignalR 使用 | 更新日期: 2023-09-27 17:58:49

我刚开始使用SignalR,我想知道如何让它为我手头的任务工作。

假设我有一个大小为30的列表(C#)。我想一次向客户推送该列表的x号。客户端将传入x,然后服务器将传出x乘x,直到列表结束。

我有一个代码在工作,但它显示出奇怪的结果。希望有人能帮助我。

我的代码是:

我的PersistentConnection类

public class MyConnection1 : PersistentConnection
    {
        protected override Task OnConnected(IRequest request, string connectionId)
        {
            return Connection.Broadcast("connection " + connectionId + " connected!");
        }
        protected override Task OnReceived(IRequest request, string connectionId, string data)
        {
            int milisecons = 2000;
            List<string> myList = new List<string>();
            myList.Add("1");
            myList.Add("2");
            myList.Add("3");
            myList.Add("4");
            myList.Add("5");
            myList.Add("6");
            myList.Add("7");
            myList.Add("8");
            myList.Add("9");
            myList.Add("10");
            myList.Add("11");
            myList.Add("12");
            myList.Add("13");
            myList.Add("14");
            myList.Add("15");
            myList.Add("16");
            myList.Add("17");
            myList.Add("18");
            myList.Add("19");
            myList.Add("20");
            myList.Add("21");
            myList.Add("22");
            myList.Add("23");
            myList.Add("24");
            myList.Add("25");
            myList.Add("26");
            myList.Add("27");
            myList.Add("28");
            myList.Add("29");
            myList.Add("30");
            int no = Convert.ToInt32(data);
            var dividedGroupList = myList.Select((x, i) => new { Index = i, Value = x }).GroupBy(x => x.Index / no).Select(x => x.Select(v => v.Value).ToList()).ToList();
            dividedGroupList.ForEach(x => { Connection.Send(connectionId, x); Thread.Sleep(milisecons); });
            return null;
        }
        protected override Task OnDisconnected(IRequest request, string connectionId)
        {
            return Connection.Broadcast("connection " + connectionId + " disconnected!");
        }
    }

我的HTML页面

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <script src="Scripts/jquery-1.10.2.min.js"></script>
    <script src="Scripts/jquery.signalR-2.0.0.min.js"></script>
</head>
<body>
    <script type="text/javascript">
        $(function () {
            var connection = $.connection('/echo');
            connection.start().done(function () {
                $('#message').append('<li>yay</li>');
            });
            $("#btn").click(function () {
                connection.send($('#msg').val());
                connection.received(function (data) {
                    $('#message').append('<li>' + data + '</li>');
                });
            });
            $("#dcbtn").click(function () {
                connection.stop();
            });
        });
    </script>
    <input type="text" id="msg" />
    <input type="button" id="btn" value=" ME!" />
    <input type="button" id="dcbtn" value=" DC" />
    <ul id="message"></ul>
</body>
</html>

第一次按下"ME!"按钮时的输出(很抱歉没有足够的信誉在这里发布图像)

•yay
•1,2,3,4,5,6,7,8,9,10
•11,12,13,14,15,16,17,18,19,20
•21,22,23,24,25,26,27,28,29,30

第二次按下"ME!"按钮

•yay
•1,2,3,4,5,6,7,8,9,10
•11,12,13,14,15,16,17,18,19,20
•21,22,23,24,25,26,27,28,29,30
•1,2,3,4,5,6,7,8,9,10                        <==== repeated here onwards
•1,2,3,4,5,6,7,8,9,10                           
•11,12,13,14,15,16,17,18,19,20
•11,12,13,14,15,16,17,18,19,20
•21,22,23,24,25,26,27,28,29,30
•21,22,23,24,25,26,27,28,29,30

无论我是否单击"DC"按钮(调用了"connection.stop()"方法),重复次数都将不断增加1。

任何建议都足够

非常感谢!

已编辑我使用Hubs成功地完成了这项工作。然而,我仍然想知道在这个低水平上到底发生了什么。我在这里做错了什么?

使用SignalR流式传输数据

首先,只有当您有特定的场景需要时,才应该使用PersistentConnection,而应该使用Hubs。

其次,永远不应该阻塞Hub或PersistentConnection对象中的线程——该对象表示一个连接操作,因此它在连接事件、断开连接事件或方法调用的生命周期内是瞬态的。

相反,创建一个应用程序,然后可以调用集线器——在应用程序中维护计时器。请参阅以下内容了解如何呼叫集线器:

http://www.asp.net/signalr/overview/signalr-20/hubs-api/hubs-api-guide-server#callfromoutsidehub