当前位置: 首页 > wzjs >正文

湖北建设网站信息查询中心apache添加网站

湖北建设网站信息查询中心,apache添加网站,网站下拉菜单怎么做,wordpress 修复在 Web 开发中,后端存在一些值得注意的通信协议,用于将更改通知给已连接的客户端。所有这些协议都用于处理同一件事。但鲜为人知的协议很少,鲜为人知的协议也很少。今天,将讨论 WebSocket,它在开发中使用最少&#xff…

        在 Web 开发中,后端存在一些值得注意的通信协议,用于将更改通知给已连接的客户端。所有这些协议都用于处理同一件事。但鲜为人知的协议很少,鲜为人知的协议也很少。今天,将讨论 WebSocket,它在开发中使用最少,但它速度很快,是所有协议的根源!它通过单个持久连接在客户端和服务器之间进行全双工双向通信。这与传统的 HTTP 协议形成了鲜明对比,因为传统的 HTTP 协议每个请求-响应周期都需要建立新的连接。WebSocket 非常适合实时应用程序,因为它们允许服务器将数据推送到客户端,而无需等待客户端请求。

        将使用 .NET Core Web API 应用程序进行演示。希望大家知道如何使用 Visual Studio 创建 .NET Core Web API 应用程序。因此,不会从头开始演示,而是重点介绍如何在现有应用程序中使用它,并在发生任何更改后通知连接的客户端。

1. 将 WebSocket 添加到应用程序

修改您的Program.cs以启用 WebSockets。

var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();

app.UseWebSockets();
app.UseRouting();

app.MapControllers();

app.Run();

2.创建WebSocket服务

创建服务和接口来管理 WebSocket 连接。

namespace GraphicsBackend.Services
{
public interface IWebSocketService
{
Task AddSocketAsync(WebSocket webSocket);
Task BroadcastAsync(SocketMessage message);
Task NotifyClientsAsync(string message);
}
}

namespace GraphicsBackend.Services
{

    public class WebSocketService : IWebSocketService
{
private static readonly List<WebSocket> _connections = new();
public async Task AddSocketAsync(WebSocket webSocket)
{
_connections.Add(webSocket);
var buffer = new byte[1024 * 4];
while (webSocket.State == WebSocketState.Open)
{
var result = await webSocket.ReceiveAsync(new ArraySegment<byte>(buffer), CancellationToken.None);
if (result.MessageType == WebSocketMessageType.Close)
{
_connections.Remove(webSocket);
await webSocket.CloseAsync(WebSocketCloseStatus.NormalClosure, "Closed by client", CancellationToken.None);
}
}

        }
public async Task NotifyClientsAsync(string message)
{
var tasks = _connections
.Where(s => s != null && s.State == WebSocketState.Open)
.Select(s => s.SendAsync(
new ArraySegment<byte>(Encoding.UTF8.GetBytes(message)),
WebSocketMessageType.Text, true, CancellationToken.None));

            await Task.WhenAll(tasks);
}

        public async Task BroadcastAsync(SocketMessage message)
{
var serializedMessage = JsonConvert.SerializeObject(message);
await NotifyClientsAsync(serializedMessage);
}
}

3.创建 WebSocket 控制器

该控制器将处理 WebSocket 连接。

[Route("ws")]
[ApiController]
public class WebSocketController : ControllerBase
{
private readonly IWebSocketService _webSocketService;

    public WebSocketController(IWebSocketService  webSocketService)
{
_webSocketService= webSocketService;
}

    [HttpGet]
public async Task Get()
{
if (HttpContext.WebSockets.IsWebSocketRequest)
{
using var webSocket = await HttpContext.WebSockets.AcceptWebSocketAsync();
await _webSocketService.AddSocketAsync(webSocket);
}
else
{
HttpContext.Response.StatusCode = 400;
}
}
}

4. 将 WebSocketService 注入服务

在Program.cs中注册WebSocketService和IWebSocketService,以便可以在整个应用程序中使用它。

var builder = WebApplication.CreateBuilder(args);

builder.Services.AddSingleton<IWebSocketService,WebSocketService>();

var app = builder.Build();

app.UseWebSockets();
app.MapControllers();

app.Run();

5. 通知客户端 API 操作中的任何操作

修改您的 API 控制器以发送通知。

[Route("api/customers")]
[ApiController]
public class HomeController: ControllerBase
{
private readonly IWebSocketService _webSocketService;

    public CustomerController(IWebSocketService  webSocketService)
{
_webSocketService= webSocketService;
}

    [HttpPost]
public async Task<IActionResult> Create([FromBody] Model model)
{
// Save customer to DB (your logic)

        // Notify clients
await _webSocketService.NotifyClientsAsync("New model added!");

        return Ok();
}
}

6. 从前端连接

使用 JavaScript 监听来自 WebSocket 的消息。

const socket = new WebSocket("ws://localhost:5000/ws");

socket.onmessage = function(event) {
console.log("Notification received:", event.data);
};

socket.onopen = function() {
console.log("WebSocket connected!");
};

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。


文章转载自:

http://EPvBtkVJ.zqdhr.cn
http://xprQryz9.zqdhr.cn
http://5PjhEjkx.zqdhr.cn
http://nszAjCGP.zqdhr.cn
http://DsHOTKsO.zqdhr.cn
http://xtYihsu3.zqdhr.cn
http://PJ7JuoKc.zqdhr.cn
http://omPm5TsU.zqdhr.cn
http://cuTR08AI.zqdhr.cn
http://ehoiRyK6.zqdhr.cn
http://iZNaOitq.zqdhr.cn
http://fdffwdOo.zqdhr.cn
http://h9YW1RX5.zqdhr.cn
http://DSBFp3xE.zqdhr.cn
http://hpbuXMBN.zqdhr.cn
http://KLKdbdsn.zqdhr.cn
http://EznFubR1.zqdhr.cn
http://oaqgVZpE.zqdhr.cn
http://Vbtrayos.zqdhr.cn
http://wDoByr5o.zqdhr.cn
http://DXttO0r0.zqdhr.cn
http://UTR7Duwo.zqdhr.cn
http://dnjG3t95.zqdhr.cn
http://9ylk61fT.zqdhr.cn
http://J7ijdcal.zqdhr.cn
http://na12HOtl.zqdhr.cn
http://oLrGU2nh.zqdhr.cn
http://emg28R54.zqdhr.cn
http://sDlTNeRv.zqdhr.cn
http://czT3TuiX.zqdhr.cn
http://www.dtcms.com/wzjs/723100.html

相关文章:

  • 园林景观网站模板好2345浏览器主页
  • 免费资源源码网站网站和微信订阅号优势
  • 一站式网站建设报价wordpress 加速js插件
  • 虚拟主机手机网站邢台网站建设与制作
  • 中远智达网站建设网站设计的基本知识结构
  • 浙江交工宏途交通建设有限公司网站建立网站数据库
  • 做网站应该问客户什么需求网页游戏开服表好吗
  • 西部空间官方网站邵阳做网站
  • 给企业做网站 工作wordpress 中文api
  • 网站开发中文摘要国外的电商平台
  • 网站开发工程师面试问题网站弹出广告gif出处
  • 制作网线的线序百度 排名seo快速
  • 南宁网站seo外包十大高端网站定制设计师
  • 如何让百度快速收录网站公司起名字免费软件
  • 基础网站开发小制作简单又漂亮
  • 注册网站域名平台中国小康建设网官方网站
  • h5游戏平台搭建团购网站如何优化
  • 电商网站建设成本做logo图标的网站
  • 名字找备案网站网站广告动态图怎么做
  • 11免费建网站中文wordpress插件
  • 江门网页模板建站陕西建设网官网登录
  • 成都哪家做网站最好温州市鹿城区建设小学网站
  • 外贸网站建设高端的营销知识和技巧
  • 编程自学免费网站八亿wap建站
  • 网站建设投资大概每年需要多少钱固安企业网站建设
  • 河南住房和城乡建设局网站学生创业做网站制作设计
  • 加人引流加人网站怎么做网站开发前端工程师
  • 手机网站制作得多少钱啊注册网站用什么邮箱
  • 上海网址大全大连网站优化公司
  • 网站科技感页面设计官网建设设计