C# TcpClient

2024-05-29 11:12
文章标签 c# .net netcore tcpclient

本文主要是介绍C# TcpClient,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

TcpClient 自己封装的话,还是比较麻烦的,可以基于线程,也可以基于异步写,最好的办法是网上找个插件,我发现一个插件还是非常好用的:STTech.BytesIO.Tcp

下面是这个插件作者的帖子,有兴趣的可以去看看

TcpClient

BytesIO | 零基础轻松看懂 C# TCP客户端(完整源码+视频教程)_sttech.bytesio.tcp-CSDN博客

TcpServer

BytesIO | C# 超简洁的TCP服务端开发(完整源码+视频教程)_c# bytesio-CSDN博客

目前网上大部分帖子都是用 PropertyGrid 控件去实现的,其实没必要

我做了一个简单的界面,如下

代码:

using System;
using System.Collections.Generic;
using System.Windows.Forms;namespace TcpClinetTest2
{public partial class Form1 : Form{public Form1(){InitializeComponent();}STTech.BytesIO.Tcp.TcpClient tcpClient;private void Form1_Load(object sender, EventArgs e){this.tcpClient = new STTech.BytesIO.Tcp.TcpClient();//tcp接收数据时触发的事件this.tcpClient.OnDataReceived += TcpClient_OnDataReceived;//tcp连接成功时触发的事件this.tcpClient.OnConnectedSuccessfully += TcpClient_OnConnectedSuccessfully;//tcp连接断开时触发的事件this.tcpClient.OnDisconnected += TcpClient_OnDisconnected;}private void Form1_FormClosing(object sender, FormClosingEventArgs e){if (this.tcpClient.IsConnected)this.tcpClient.Disconnect();}private void TcpClient_OnDisconnected(object sender, STTech.BytesIO.Core.DisconnectedEventArgs e){Console.WriteLine($"已断开:{e.ReasonCode}");}private void TcpClient_OnConnectedSuccessfully(object sender, STTech.BytesIO.Core.ConnectedSuccessfullyEventArgs e){Console.WriteLine("连接成功");}private void TcpClient_OnDataReceived(object sender, STTech.BytesIO.Core.DataReceivedEventArgs e){Console.WriteLine($"收到数据:{e.Data.EncodeToString("GBK")}");}//连接private void Button_Connect_Click(object sender, EventArgs e){this.tcpClient.Host = "192.168.30.91";this.tcpClient.Port = 6666;var result = this.tcpClient.Connect();Console.WriteLine($"结果:{result.IsSuccess},错误码:{result.ErrorCode}");}//断开private void Button_Disconnect_Click(object sender, EventArgs e){this.tcpClient?.Disconnect();}//发送private void Button_Send_Click(object sender, EventArgs e){string message = TextBox_Message.Text;if (string.IsNullOrEmpty(message)){Console.WriteLine("消息框为空");return;}this.tcpClient.Send(message.GetBytes("GBK"));}//清空控制台private void Button_ClearConsole_Click(object sender, EventArgs e){Console.Clear();}//获取在线状态private void Button_GetOnlineStatus_Click(object sender, EventArgs e){Console.WriteLine($"在线状态:{this.tcpClient.IsConnected}");}}
}

end

这篇关于C# TcpClient的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1013503

相关文章

C#特性(Attributes)和反射(Reflection)详解

《C#特性(Attributes)和反射(Reflection)详解》:本文主要介绍C#特性(Attributes)和反射(Reflection),具有很好的参考价值,希望对大家有所帮助,如有错误... 目录特性特性的定义概念目的反射定义概念目的反射的主要功能包括使用反射的基本步骤特性和反射的关系总结特性

C#实现查找并删除PDF中的空白页面

《C#实现查找并删除PDF中的空白页面》PDF文件中的空白页并不少见,因为它们有可能是作者有意留下的,也有可能是在处理文档时不小心添加的,下面我们来看看如何使用Spire.PDFfor.NET通过C#... 目录安装 Spire.PDF for .NETC# 查找并删除 PDF 文档中的空白页C# 添加与删

通过C#获取Excel单元格的数据类型的方法详解

《通过C#获取Excel单元格的数据类型的方法详解》在处理Excel文件时,了解单元格的数据类型有助于我们正确地解析和处理数据,本文将详细介绍如何使用FreeSpire.XLS来获取Excel单元格的... 目录引言环境配置6种常见数据类型C# 读取单元格数据类型引言在处理 Excel 文件时,了解单元格

C#实现高性能Excel百万数据导出优化实战指南

《C#实现高性能Excel百万数据导出优化实战指南》在日常工作中,Excel数据导出是一个常见的需求,然而,当数据量较大时,性能和内存问题往往会成为限制导出效率的瓶颈,下面我们看看C#如何结合EPPl... 目录一、技术方案核心对比二、各方案选型建议三、性能对比数据四、核心代码实现1. MiniExcel

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

C#如何调用C++库

《C#如何调用C++库》:本文主要介绍C#如何调用C++库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录方法一:使用P/Invoke1. 导出C++函数2. 定义P/Invoke签名3. 调用C++函数方法二:使用C++/CLI作为桥接1. 创建C++/CL

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

C# foreach 循环中获取索引的实现方式

《C#foreach循环中获取索引的实现方式》:本文主要介绍C#foreach循环中获取索引的实现方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、手动维护索引变量二、LINQ Select + 元组解构三、扩展方法封装索引四、使用 for 循环替代

C# Where 泛型约束的实现

《C#Where泛型约束的实现》本文主要介绍了C#Where泛型约束的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用的对象约束分类where T : structwhere T : classwhere T : ne

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel