SignalR in ASP.NET WebForms

本文关键字:WebForms NET ASP in SignalR | 更新日期: 2023-09-27 18:25:22

在我的一个项目中,我需要使用SignalR库。所以我决定创建一个简单的应用程序来检查它是如何工作的。我根据一些教程创建了这个应用程序,这些教程展示了如何编写聊天室
唯一的区别是,我的项目是WebForms,我也在其中使用ASP.NET控件

这就是我迄今为止所做的:

  1. 我安装了SignalR

  2. 我创建了ChatHub文件:

ChatHub.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using Microsoft.AspNet.SignalR;
using Microsoft.AspNet.SignalR.Hubs;    
namespace SignalRTest
{
    public class ChatHub : Hub
    {
        public void sendMessage(string msg)
        {
            Clients.All.addMessage(msg);
        }
    }
}
  1. 在Default.aspx页面中:

<html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
    <title></title>
    <script src="Scripts/jquery-1.10.2.min.js"></script>
    <script src="Scripts/jquery.signalR-2.2.0.min.js"></script>
    <script src="/signalr/hubs"></script>
    <script type="text/javascript">
        $(function () {
            var chat = $.connection.chatHub;
            chat.client.addMessage = function (msg) {
                $('#chat_list').append("<li>" + msg + "</li>");
            };
            $.connection.hub.start().done(function () {
                $('#Button1').click(function () {
                    chat.server.sendMessage($('#TextBox1').val());
                });
            });
        });
    </script>
    </head>
    <body>
        <form id="form1" runat="server">
            <div>
                <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
                <asp:Button ID="Button1" runat="server" Text="Send" />
            </div>
            <div>
                <ul id="chat_list">
                </ul>
            </div>
        </form>
    
    </body>
</html>

  1. 启动文件:

启动.cs

using Microsoft.Owin;
using Owin;
[assembly: OwinStartup(typeof(SignalRTest.Startup))]
namespace SignalRTest
{
    public partial class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            app.MapSignalR();
        }
    }
}

我设置了断点,点击发送按钮会在服务器上触发sendMessage方法,在客户端也会添加MessageJS函数。但问题是:

当我向其他用户发送内容时,他可以在<ul></ul>元素中看到该消息。但不是我。然后当他给我回复时,我可以看到,但他的名单被清除了。

它可能是由使用ASP控件引起的吗
我不确定我是否以最佳方式获得了对这些控件的引用。

PS。很抱歉格式不正确,但我无法处理C#代码。

SignalR in ASP.NET WebForms

您的问题是希望您的按钮同时运行服务器端和激发javascript代码。

<asp:Button ID="Button1" runat="server" Text="Send" />

runat="server"位意味着您将看到页面刷新,因为应用程序将尝试运行服务器端代码,因此消息将清除。

如果您在一个普通的html元素上运行代码,那么这个代码应该可以正常工作。

I.E.目标:

<input ID="Button1" type="button" value="Send" />