#region copyright //------------------------------------------------------------------------------ // 此代码版权声明为全文件覆盖,如有原作者特别声明,会在下方手动补充 // 此代码版权(除特别声明外的代码)归作者本人Diego所有 // 源代码使用协议遵循本仓库的开源协议及附加协议 // Gitee源代码仓库:https://gitee.com/diego2098/ThingsGateway // Github源代码仓库:https://github.com/kimdiego2098/ThingsGateway // 使用文档:https://diego2098.gitee.io/thingsgateway-docs/ // QQ群:605534569 //------------------------------------------------------------------------------ #endregion namespace ThingsGateway.Foundation.Demo; /// public partial class TcpServerPage : IDisposable { /// /// 日志输出 /// public Action LogAction; private TouchSocketConfig config; private string ip = "127.0.0.1"; private int port = 502; private TcpService TcpServer { get; set; } = new(); private void Connect() { try { TcpServer.Stop(); GetTcpServer().Start(); } catch (Exception ex) { LogAction?.Invoke(LogLevel.Error, null, null, ex); } } private void DisConnect() { try { TcpServer.Stop(); } catch (Exception ex) { LogAction?.Invoke(LogLevel.Error, null, null, ex); } } /// /// 获取对象 /// /// public TcpService GetTcpServer() { config ??= new TouchSocketConfig(); var LogMessage = new LoggerGroup() { LogLevel = LogLevel.Trace }; LogMessage.AddLogger(new EasyLogger(LogOut) { LogLevel = LogLevel.Trace }); config.ConfigureContainer(a => a.RegisterSingleton(LogMessage)); config.SetListenIPHosts(new IPHost[] { new IPHost(ip + ":" + port) }); //载入配置 TcpServer.Setup(config); return TcpServer; } /// protected override void OnInitialized() { config ??= new TouchSocketConfig(); base.OnInitialized(); } /// /// /// /// protected override void OnAfterRender(bool firstRender) { if (firstRender) { var LogMessage = new LoggerGroup() { LogLevel = LogLevel.Trace }; LogMessage.AddLogger(new EasyLogger(LogOut) { LogLevel = LogLevel.Trace }); config.ConfigureContainer(a => a.RegisterSingleton(LogMessage)); config.SetListenIPHosts(new IPHost[] { new IPHost(ip + ":" + port) }); TcpServer.Setup(config); } base.OnAfterRender(firstRender); } private void LogOut(LogLevel logLevel, object source, string message, Exception exception) => LogAction?.Invoke(logLevel, source, message, exception); /// /// /// public void Dispose() { TcpServer.SafeDispose(); } internal void StateHasChangedAsync() { StateHasChanged(); } }