C# Socket 通信
C# Socket通信
Socket通信主要分为两部分,服务端和客户端,其中服务端和客户端都具有接收消息和发送消息的功能,具体通信流程就是服务端先去监听一个端口号,等待客户端的连接,客户端通过指定IP和端口号去连接服务端,最终实现相互通信。具体代码如下:
服务端
首先对端口进行监听
/// <summary>
/// 监听端口
/// </summary>
/// <param name="port">端口号</param>
public void Listen(int port)
{
Log_txt.AppendText("正在监听端口" + port + "\r\n");
Task.Run(() =>//开启新线程用于监听端口
{
try
{
IPEndPoint iPEndPoint = new IPEndPoint(IPAddress.Any, port);
Socket socketListener = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
socketListener.Bind(iPEndPoint);//绑定端口号
socketListener.Listen(1000);//设置最大监听数
while (IsListening)//bool类型 表示是否监听
{
try
{
Socket socketAccepter = socketListener.Accept();//负责监听的socket
hashtable.Add(port, socketAccepter);//hashtable用于存储端口以及对应的socket对象 便于后续通信使用
Log_txt.AppendText(socketAccepter.RemoteEndPoint + "连接成功!\r\n");
Task.Run(() => { Recive(socketAccepter); });//开启新线程用于接收消息
}
catch (Exception x)
{
}
}
}
catch (Exception e)
{ }
});
}
完成监听后,就需要有一个方法来接收消息
/// <summary>
/// 接收消息
/// </summary>
/// <param name="socketAccepter">接收消息</param>
public void Recive(Socket socketAccepter)
{
while (IsAccepting)//bool类型 表示是否接收消息
{
try
{
byte[] buffer = new byte[1024 * 1024 * 10];//用于接收数据
int i = socketAccepter.Receive(buffer);//接收到的字节数
string msg = Encoding.UTF8.GetString(buffer, 0, i);//以UTF-8编码格式转换成字符串
LogInfo(2, socketAccepter.RemoteEndPoint + "收到消息:" + msg);//显示日志
}
catch (Exception e)
{ }
}
}
Socket通信,当然不能只有接收消息,还需要一个发送消息的方法,具体代码如下
/// <summary>
/// 发送消息
/// </summary>
/// <param name="socketAccepter">负责通信的socket</param>
/// <param name="Msg">要发送的消息</param>
public void SendMsg(Socket socketAccepter,string Msg)
{
if (!string.IsNullOrEmpty(Msg.Trim()) && socketAccepter != null)
{
byte[] buffer = Encoding.UTF8.GetBytes(Msg);
socketAccepter.Send(buffer);
LogInfo(1, "发送消息:" + Msg);
}
}
这样就完成了服务端的监听、接收和发送功能。还有一个显示日志方法 ,这里只是一个简单的显示到窗体日志框中,并没有写入日志文件,有需求的可以去看看Log4的使用方法。方法如下:
/// <summary>
/// 显示日志
/// </summary>
/// <param name="level">日志等级</param>
/// <param name="LogText">日志内容</param>
public void LogInfo(int level,string LogText)
{
switch (level)//根据日志等级呈现不同样式的消息
{
case 1://发送消息
Log_txt.SelectionColor = Color.Red;
break;
case 2://接收消息
Log_txt.SelectionColor = Color.Green;
break;
default:
Log_txt.SelectionColor = Color.Yellow;
break;
}
Log_txt.AppendText(LogText + "\r\n");
}
客户端
Socket 客户端的实现就是通过一个Socket对象去访问指定IP和端口号,代码如下:
public void Connect(string ip,int port)
{
IPEndPoint iPEndPoint = new IPEndPoint(IPAddress.Parse(ip), port);
Socket ConnectSocket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
ConnectSocket .Connect(iPEndPoint);//连接服务端
Task.Run(() =>
{
Recive(ConnectSocket );//开启新线程用于接收消息
});
}
由于我是写在一个Form窗体中的,所以接收和发送方法是一样的,如果想分开可以分别写接收和发送方法。下面是类中的一些字段 供参考
Hashtable hashtable = new Hashtable();//用于存储端口以及对应的Socket对象
bool IsListening;//是否监听
bool IsAccepting;//是否接收消息
Encoding Encoding = Encoding.Default;//编码格式
这样一个简单的Socket通信就完成了,关于Socket通信如果你有疑惑或者更好的建议也欢迎一起讨论学习。
C# Socket 通信的更多相关文章
- 我看不下去鸟。。。。Java和C#的socket通信真的简单吗?
这几天在博客园上看到好几个写Java和C#的socket通信的帖子.但是都为指出其中关键点. C# socket通信组件有很多,在vs 使用nuget搜索socket组件有很多类似的.本人使用的是自己 ...
- php简单实现socket通信
socket通信的原理在这里就不说了,它的用途还是比较广泛的,我们可以使用socket来做一个API接口出来,也可以使用socket来实现两个程序之间的通信,我们来研究一下在php里面如何实现sock ...
- Socket通信类
package com.imooc; import java.io.BufferedReader; import java.io.IOException; import java.io.InputSt ...
- AgileEAS.NET SOA 中间件平台.Net Socket通信框架-介绍
一.前言 AgileEAS.NET SOA 中间件平台是一款基于基于敏捷并行开发思想和Microsoft .Net构件(组件)开发技术而构建的一个快速开发应用平台.用于帮助中小型软件企业建立一条适合市 ...
- socket通信
socket通信 一:socket基于Tcp连接,数据传输有保证 二:socket连接的建立过程: 1:服务器监听 2:客户端发出请求 3:建立连接 4:通信 三:一个简单的例子:服务器端每隔一段时间 ...
- Android之Socket通信、List加载更多、Spinner下拉列表
Android与服务器的通信方式主要有两种,一是Http通信,一是Socket通信.两者的最大差异在于,http连接使用的是“请求—响应方式”,即在请求时建立连接通道,当客户端向服务器发送请求后,服务 ...
- .NET开源高性能Socket通信中间件Helios介绍及演示
一:Helios是什么 Helios是一套高性能的Socket通信中间件,使用C#编写.Helios的开发受到Netty的启发,使用非阻塞的事件驱动模型架构来实现高并发高吞吐量.Helios为我们大大 ...
- iOS开发之Socket通信实战--Request请求数据包编码模块
实际上在iOS很多应用开发中,大部分用的网络通信都是http/https协议,除非有特殊的需求会用到Socket网络协议进行网络数 据传输,这时候在iOS客户端就需要很好的第三方CocoaAsyncS ...
- AgileEAS.NET SOA 中间件平台.Net Socket通信框架-简单例子-实现简单的服务端客户端消息应答
一.AgileEAS.NET SOA中间件Socket/Tcp框架介绍 在文章AgileEAS.NET SOA 中间件平台Socket/Tcp通信框架介绍一文之中我们对AgileEAS.NET SOA ...
- AgileEAS.NET SOA 中间件平台.Net Socket通信框架-完整应用例子-在线聊天室系统-下载配置
一.AgileEAS.NET SOA中间件Socket/Tcp框架介绍 在文章AgileEAS.NET SOA 中间件平台Socket/Tcp通信框架介绍一文之中我们对AgileEAS.NET SOA ...
随机推荐
- JZOJ 2933. 【NOIP2012模拟8.7】找位置
题目大意 有 \(n(1 \leq n \leq 10000)\) 个城镇,由 \(1 \leq m \leq 50000\) 条无向道路连接.给出 \(k(1 \leq k \leq 5) 个超市\ ...
- SpringCloud 源码学习笔记2——Feign声明式http客户端源码分析
系列文章目录和关于我 一丶Feign是什么 Feign是一种声明式. 模板化的HTTP客户端.在Spring Cloud中使用Feign,可以做到使用HTTP请求访问远程服务,就像调用本地方法一一样的 ...
- 关于 Knex update 语句报错:Undefined binding(s) detected when compiling UPDATE
下图是详细的报错截图,我敢保证前端传递的数据一个不漏,但还是报我没有绑定对应的字段: 官方文档的使用案例基本上都是where 子句在 update 语句之前.但,select 语句的 where 子句 ...
- OpenLayers点聚合
1. 引言 当页面加载的数据量过大时,拖拽.缩放时往往会产生卡顿 然而,页面实现的内容是有限的,人眼可见范围也是有限的,过于微小的部分是可以不予显示的 聚合是解决这种问题的一个办法,当数据比较多,单个 ...
- Dev Express 框架自定义登录添加短信验证功能
需求:登录界面改成这样 记录一下过程,以便下次操作类似的步骤有遗忘,也与大伙儿分享下,如有不当之处请指出,感谢. 参考官网文档:https://docs.devexpress.com/eXpressA ...
- tinyriscv仿真环境
环境要求:iverilog gtkwave 在sim目录新建makefile,内容如下. BIN=rv32ui-p-jal all: hexf comp vvp hexf: cp ../tests/i ...
- vue3学习
资料: http://docs.vikingship.xyz/ 声明类型: 1.使用ref可以声明基础数据 2.使用reactive声明对象数据 3.computed可以返回一个不变的响应式 ...
- 001、nodelocaldns(/etc/resolv.conf)
nodelocaldns pod 中的 /etc/resolv.conf 虽然读取的是 宿主机的/etc/resolv.conf,但是不是实时同步更新的.可能同步更新会有延迟 所以如果 /etc/ ...
- mybatis日志打印到控制台
mybatis: configuration:# 日志输出到控制台 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
- Django,Flask中的request
request的结构获取 class Upload(Resource): def post(self): print(curPath) print(request.files['file'].__di ...