簡體   English   中英

WebSocket錯誤:錯誤的HTTP響應。 狀態碼400,請求錯誤

[英]WebSocket Error: Incorrect HTTP response. Status code 400, Bad Request

我嘗試按此處記錄的那樣為ASP.NET Core實施SignalR: https ://aspnetboilerplate.com/Pages/Documents/SignalR-AspNetCore-Integration

但是我總是會出錯。 瀏覽器控制台輸出:

DEBUG: 
Starting connection using WebSockets transport
Information: Normalizing '/signalr-myChatHub' to 'http://localhost:62114/signalr-myChatHub'
SCRIPT12008: WebSocket Error: Incorrect HTTP response. Status code 400, Bad Request

我正在使用所有軟件包3.6.2和Abp.AspNetCore.SignalR 3.6.2-preview6的最新版本。

Web.Host/Startup.cs

#elif FEATURE_SIGNALR_ASPNETCORE
    app.UseSignalR(routes =>
    {
        routes.MapHub<AbpCommonHub>("/signalr");
        routes.MapHub<MyChatHub>("/signalr-myChatHub"); // Prefix with '/signalr'
    });
#endif

復制粘貼的MyChatHub.cs

public class MyChatHub : Hub, ITransientDependency
{
    public IAbpSession AbpSession { get; set; }

    public ILogger Logger { get; set; }

    public MyChatHub()
    {
        AbpSession = NullAbpSession.Instance;
        Logger = NullLogger.Instance;
    }

    public async Task SendMessage(string message)
    {
        await Clients.All.SendAsync("getMessage", string.Format("User {0}: {1}", AbpSession.UserId, message));
    }

    public override async Task OnConnectedAsync()
    {
        await base.OnConnectedAsync();
        Logger.Debug("A client connected to MyChatHub: " + Context.ConnectionId);
    }

    public override async Task OnDisconnectedAsync(Exception exception)
    {
        await base.OnDisconnectedAsync(exception);
        Logger.Debug("A client disconnected from MyChatHub: " + Context.ConnectionId);
    }
}

或多或少復制粘貼的視圖:

@using EMetall.Web.Startup

@section scripts
{
    <environment names="Development">
        <script src="~/lib/signalr-client/signalr.min.js"></script>
        <script src="~/lib/abp-web-resources/Abp/Framework/scripts/libs/abp.signalr-client.js"></script>
    </environment>

    <script type="text/javascript">
        $(function () {
            var chatHub = null;

            abp.signalr.startConnection('/signalr-myChatHub', function (connection) {
                chatHub = connection; // Save a reference to the hub

                connection.on('getMessage', function (message) { // Register for incoming messages
                    console.log('received message: ' + message);
                });
            }).then(function (connection) {
                console.log('Connected to myChatHub server!');
                abp.event.trigger('myChatHub.connected');
            });

            abp.event.on('myChatHub.connected', function() { // Register for connect event
                chatHub.invoke('sendMessage', "Hi everybody, I'm connected to the chat!"); // Send a message to the server
            });
        });
    </script>
}

您需要使用以下兼容版本:

從4.2版開始,它可以直接使用。

您只需要下載它,然后創建chathup,注冊路線並在視圖中調用它即可。 大。

請參閱示例,以進行組裝,布線和查看: https ://aspnetboilerplate.com/Pages/Documents/SignalR-AspNetCore-Integration

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM