152 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| #region copyright
 | ||
| //------------------------------------------------------------------------------
 | ||
| //  此代码版权声明为全文件覆盖,如有原作者特别声明,会在下方手动补充
 | ||
| //  此代码版权(除特别声明外的代码)归作者本人Diego所有
 | ||
| //  源代码使用协议遵循本仓库的开源协议及附加协议
 | ||
| //  Gitee源代码仓库:https://gitee.com/diego2098/ThingsGateway
 | ||
| //  Github源代码仓库:https://github.com/kimdiego2098/ThingsGateway
 | ||
| //  使用文档:https://diego2098.gitee.io/thingsgateway-docs/
 | ||
| //  QQ群:605534569
 | ||
| //------------------------------------------------------------------------------
 | ||
| #endregion
 | ||
| 
 | ||
| using Masa.Blazor;
 | ||
| 
 | ||
| using Microsoft.AspNetCore.Components;
 | ||
| 
 | ||
| using MQTTnet;
 | ||
| using MQTTnet.Extensions.Rpc;
 | ||
| 
 | ||
| using System.Collections.Generic;
 | ||
| using System.Text;
 | ||
| 
 | ||
| using ThingsGateway.Plugin.Mqtt;
 | ||
| 
 | ||
| namespace ThingsGateway.Foundation.Demo;
 | ||
| 
 | ||
| /// <summary>
 | ||
| /// MqttClientDebugPage
 | ||
| /// </summary>
 | ||
| public partial class MqttClientDebugPage : IDisposable
 | ||
| {
 | ||
|     private DriverDebugUIPage driverDebugUIPage;
 | ||
|     private MqttClientPage mqttClientPage;
 | ||
| 
 | ||
|     [Inject]
 | ||
|     IPopupService PopupService { get; set; }
 | ||
| 
 | ||
|     /// <inheritdoc/>
 | ||
|     public void Dispose()
 | ||
|     {
 | ||
|         mqttClientPage.SafeDispose();
 | ||
|     }
 | ||
|     /// <inheritdoc/>
 | ||
|     protected override void OnAfterRender(bool firstRender)
 | ||
|     {
 | ||
|         if (firstRender)
 | ||
|         {
 | ||
|             if (mqttClientPage != null)
 | ||
|             {
 | ||
|                 mqttClientPage.LogAction = driverDebugUIPage.LogOut;
 | ||
|             }
 | ||
|             //初始化
 | ||
|             driverDebugUIPage.Address = "ThingsGateway/Variable";
 | ||
| 
 | ||
|             driverDebugUIPage.WriteValue = new MqttRpcNameVaueWithId()
 | ||
|             {
 | ||
|                 RpcId = Guid.NewGuid().ToString(),
 | ||
|                 WriteInfos = new Dictionary<string, string>()
 | ||
| {
 | ||
|     { "tag1", "123" }
 | ||
| }
 | ||
|             }.ToJsonString();
 | ||
|             ;
 | ||
|             mqttClientPage.IP = "127.0.0.1";
 | ||
|             mqttClientPage.Port = 1883;
 | ||
|             mqttClientPage.UserName = "admin";
 | ||
|             mqttClientPage.Password = "111111";
 | ||
|             mqttClientPage.StateHasChangedAsync();
 | ||
| 
 | ||
|             //载入配置
 | ||
|             StateHasChanged();
 | ||
|             driverDebugUIPage.Sections.Clear();
 | ||
|         }
 | ||
| 
 | ||
|         base.OnAfterRender(firstRender);
 | ||
|     }
 | ||
| 
 | ||
|     private async Task SubscribeAsync()
 | ||
|     {
 | ||
|         try
 | ||
|         {
 | ||
|             var mqttSubscribeOptions = mqttClientPage.MqttFactory.CreateSubscribeOptionsBuilder()
 | ||
| .WithTopicFilter(
 | ||
| f =>
 | ||
| {
 | ||
|     f.WithTopic(driverDebugUIPage.Address);
 | ||
| })
 | ||
| .Build();
 | ||
| 
 | ||
|             await mqttClientPage.MqttClient.SubscribeAsync(mqttSubscribeOptions, CancellationToken.None);
 | ||
|             driverDebugUIPage.Messages.Add((Microsoft.Extensions.Logging.LogLevel.Information, DateTimeExtensions.CurrentDateTime.ToDefaultDateTimeFormat(driverDebugUIPage.InitTimezone.TimezoneOffset) + " - " + $"订阅{driverDebugUIPage.Address}成功"));
 | ||
| 
 | ||
|         }
 | ||
|         catch (Exception ex)
 | ||
|         {
 | ||
|             driverDebugUIPage.Messages.Add((Microsoft.Extensions.Logging.LogLevel.Error, DateTimeExtensions.CurrentDateTime.ToDefaultDateTimeFormat(driverDebugUIPage.InitTimezone.TimezoneOffset) + " - " + ex.Message));
 | ||
|         }
 | ||
| 
 | ||
|     }
 | ||
|     private async Task UnsubscribeAsync()
 | ||
|     {
 | ||
|         try
 | ||
|         {
 | ||
|             var mqttSubscribeOptions = mqttClientPage.MqttFactory.CreateUnsubscribeOptionsBuilder()
 | ||
| .WithTopicFilter(driverDebugUIPage.Address)
 | ||
| .Build();
 | ||
| 
 | ||
|             await mqttClientPage.MqttClient.UnsubscribeAsync(mqttSubscribeOptions, CancellationToken.None);
 | ||
|             driverDebugUIPage.Messages.Add((Microsoft.Extensions.Logging.LogLevel.Information, DateTimeExtensions.CurrentDateTime.ToDefaultDateTimeFormat(driverDebugUIPage.InitTimezone.TimezoneOffset) + " - " + $"取消订阅{driverDebugUIPage.Address}成功"));
 | ||
|         }
 | ||
|         catch (Exception ex)
 | ||
|         {
 | ||
| 
 | ||
|             driverDebugUIPage.Messages.Add((Microsoft.Extensions.Logging.LogLevel.Error, DateTimeExtensions.CurrentDateTime.ToDefaultDateTimeFormat(driverDebugUIPage.InitTimezone.TimezoneOffset) + " - " + ex.Message));
 | ||
|         }
 | ||
| 
 | ||
|     }
 | ||
|     string PublishTopic;
 | ||
|     string PublishValue;
 | ||
|     private async Task PublishAsync()
 | ||
|     {
 | ||
|         try
 | ||
|         {
 | ||
|             var devMessage = new MqttApplicationMessageBuilder()
 | ||
| .WithTopic($"{PublishTopic}")
 | ||
| .WithPayload(PublishValue).Build();
 | ||
|             await mqttClientPage.MqttClient.PublishAsync(devMessage, CancellationToken.None);
 | ||
|             driverDebugUIPage.Messages.Add((Microsoft.Extensions.Logging.LogLevel.Information, DateTimeExtensions.CurrentDateTime.ToDefaultDateTimeFormat(driverDebugUIPage.InitTimezone.TimezoneOffset) + " - " + $"发布{PublishTopic}成功"));
 | ||
|         }
 | ||
|         catch (Exception ex)
 | ||
|         {
 | ||
|             driverDebugUIPage.Messages.Add((Microsoft.Extensions.Logging.LogLevel.Error, DateTimeExtensions.CurrentDateTime.ToDefaultDateTimeFormat(driverDebugUIPage.InitTimezone.TimezoneOffset) + " - " + ex.Message));
 | ||
|         }
 | ||
| 
 | ||
|     }
 | ||
|     MqttRpcTopicPair MqttRpcTopicPair = new() { RequestTopic = "ThingsGateway/RpcWrite", ResponseTopic = "ThingsGateway/RpcSub" };
 | ||
|     private async Task RpcExecuteAsync()
 | ||
|     {
 | ||
|         try
 | ||
|         {
 | ||
|             using MqttRpcClient mqttRpcClient = new(mqttClientPage.MqttClient);
 | ||
|             var data = await mqttRpcClient.ExecuteAsync(MqttRpcTopicPair, driverDebugUIPage.WriteValue, MQTTnet.Protocol.MqttQualityOfServiceLevel.AtMostOnce, TimeSpan.FromSeconds(10));
 | ||
|             var str = Encoding.UTF8.GetString(data);
 | ||
|             driverDebugUIPage.Messages.Add((Microsoft.Extensions.Logging.LogLevel.Information, DateTimeExtensions.CurrentDateTime.ToDefaultDateTimeFormat(driverDebugUIPage.InitTimezone.TimezoneOffset) + " - " + str));
 | ||
|         }
 | ||
|         catch (Exception ex)
 | ||
|         {
 | ||
|             driverDebugUIPage.Messages.Add((Microsoft.Extensions.Logging.LogLevel.Error, DateTimeExtensions.CurrentDateTime.ToDefaultDateTimeFormat(driverDebugUIPage.InitTimezone.TimezoneOffset) + " - " + ex.Message));
 | ||
|         }
 | ||
| 
 | ||
|     }
 | ||
| } | 
