AsyncLocalwithWebSocket(BlazorServer)
创始人
2024-09-21 07:31:03
0

在Blazor Server中,当使用WebSocket与客户端通信时,可能需要使用AsyncLocal来存储和传递数据。但是,由于WebSocket使用的是不同的线程,因此AsyncLocal的值在不同线程之间不会自动传递。因此,需要使用System.Threading.ExecutionContext来手动将AsyncLocal的值从一个线程传递到另一个线程。

以下是具有WebSocket和AsyncLocal功能的示例代码:

首先,在Server项目中创建一个名为WebSocketContext.cs的类来存储WebSocket和AsyncLocal数据:

public class WebSocketContext { public WebSocket WebSocket { get; set; } public AsyncLocal Value = new AsyncLocal(); }

接下来,在Blazor组件中创建WebSocket连接和上下文:

@page "/"

@using System.Net.WebSockets @using System.Threading @using Microsoft.AspNetCore.Components @inject NavigationManager NavigationManager

@code {

ClientWebSocket _webSocket;
WebSocketContext _webSocketContext;

private async Task Connect()
{
    _webSocket = new ClientWebSocket();
    await _webSocket.ConnectAsync(new Uri(NavigationManager.ToAbsoluteUri("/ws")), CancellationToken.None);

    _webSocketContext = new WebSocketContext { WebSocket = _webSocket };
    _webSocketContext.Value.Value = "test";

    var receiveThread = new Thread(async () =>
    {
        var buffer = new byte[4096];
        WebSocketReceiveResult result;

        while (_webSocket.CloseStatus.HasValue == false)
        {
            result = await _webSocket.ReceiveAsync(new ArraySegment(buffer), CancellationToken.None);

            if (result.MessageType == WebSocketMessageType.Text && result.EndOfMessage)
            {
                // Receive message from client
                var message = Encoding.UTF8.GetString(buffer, 0, result.Count);

                Console.WriteLine($"Message received: {message}");

                // Get the AsyncLocal value
                Console.WriteLine($"AsyncLocal value: {_webSocketContext.Value.Value}");
            }
        }
    });

    receiveThread.Start();
}

}

在此示例中,每当与客户端通信时,AsyncLocal的值都将传递

相关内容

热门资讯

总算了解!微扑克的辅助工具苹果... 总算了解!微扑克的辅助工具苹果,微扑克有挂么(微扑克)都是真的有挂(有挂秘笈)-哔哩哔哩;1、在微扑...
一分钟快速了解!微扑克辅助,微... 一分钟快速了解!微扑克辅助,微扑克ai机器人(微扑克)果然存在有挂(揭秘有挂)-哔哩哔哩微扑克ai机...
查到实测!微扑克ai辅助神器,... 查到实测!微扑克ai辅助神器,微扑克ai机器人(微扑克)果然是真的有挂(真的有挂)-哔哩哔哩1、下载...
实测必看!微扑克辅助器ios,... 实测必看!微扑克辅助器ios,微扑克有挂么(微扑克)一贯是真的有挂(确实有挂)-哔哩哔哩1、很好的工...
终于懂了!微扑克ai辅助工具,... 终于懂了!微扑克ai辅助工具,微扑克透牌(微扑克)原来有挂(有挂总结)-哔哩哔哩;微扑克ai辅助工具...
一分钟了解!微扑克有ai吗,微... 一分钟了解!微扑克有ai吗,微扑克有挂么(微扑克)都是是真的有挂(有挂辅助)-哔哩哔哩1、任何微扑克...
科技介绍!微扑克有机器人吗,微... 科技介绍!微扑克有机器人吗,微扑克ai机器人(微扑克)一贯存在有挂(证实有挂)-哔哩哔哩1、让任何用...
每日必看推荐!微扑克ai机器人... 每日必看推荐!微扑克ai机器人,微扑克透牌(微扑克)真是是真的有挂(有挂透明挂)-哔哩哔哩1、操作简...
交流学习经验!微扑克wpk透视... 交流学习经验!微扑克wpk透视辅助在哪下,微扑克透牌(微扑克)都是存在有挂(真是有挂)-哔哩哔哩1、...
记者发布!微扑克辅助工具怎么下... 记者发布!微扑克辅助工具怎么下载,微扑克有挂么(微扑克)一贯真的是有挂(的确有挂)-哔哩哔哩;1)微...