一、服务端代码

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Net;
  5. using System.Net.Sockets;
  6. using System.Text;
  7. using System.Threading;
  8. using System.Threading.Tasks;
  9. using System.Windows.Forms;
  10. namespace 网络编程.SockteHandel
  11. {
  12. /// <summary>
  13. /// 服务端处理类
  14. /// </summary>
  15. publicclassServerHandle
  16. {
  17. /// <summary>
  18. /// 端口号
  19. /// </summary>
  20. publicstaticstringPoint{ get;set;}
  21. /// <summary>
  22. /// IP地址
  23. /// </summary>
  24. publicstaticstringIpSite{ get;set;}
  25. /// <summary>
  26. /// 服务端信息
  27. /// </summary>
  28. publicstaticTextBoxServerMsg{ get;set;}
  29. /// <summary>
  30. /// 接收到客户端的消息
  31. /// </summary>
  32. publicstaticTextBoxReceiveMsg{ get;set;}
  33. /// <summary>
  34. /// 发送消息
  35. /// </summary>
  36. publicstaticTextBoxSendMessage{ get;set;}
  37. /// <summary>
  38. /// 负责通信的Socket
  39. /// </summary>
  40. privateSocketConnectionSocket;
  41. /// <summary>
  42. /// 监听端口
  43. /// </summary>
  44. publicvoidWatchPort()
  45. {
  46. //在服务器端创建一个负责监听ID跟端口号 的Socket
  47. Socket socketWatch =newSocket(AddressFamily.InterNetwork,SocketType.Stream,ProtocolType.Tcp);
  48. //IPAddress ip = IPAddress.Any; //监听
  49. IPAddress ip =IPAddress.Parse(IpSite);
  50. //创建端口号对象
  51. IPEndPoint pointObj =newIPEndPoint(ip,Convert.ToInt32(Point));
  52. //监听
  53. socketWatch.Bind(pointObj);
  54. ServerMsg.Text+="监听成功······\r\n ";
  55. //设定最多十个排队连接请求
  56. socketWatch.Listen(10);
  57. //开启一个新线程
  58. Thread thread =newThread(Listen);
  59. thread.IsBackground=true;
  60. thread.Start(socketWatch);
  61. }
  62. /// <summary>
  63. /// 等待客户端连接,并且创建与之通信的Socket
  64. /// </summary>
  65. /// <param name="obj"></param>
  66. voidListen(object obj)
  67. {
  68. Socket soketlisten = obj asSocket;
  69. while(true)
  70. {
  71. //等待客户端连接,并创建一个负责通信的Socket
  72. Socket socketSend = soketlisten.Accept();
  73. ServerMsg.Text+="连接成功·······"+ socketSend.RemoteEndPoint.ToString()+"\r\n";
  74. //开启一个新线程不停接收客户端发来的消息
  75. Thread reciveThread =newThread(Recive);
  76. reciveThread.IsBackground=true;
  77. reciveThread.Start(socketSend);
  78. }
  79. }
  80. /// <summary>
  81. /// 服务器端不停接收客户端发来的消息
  82. /// </summary>
  83. /// <param name="obj"></param>
  84. voidRecive(object obj)
  85. {
  86. //接收消息
  87. ConnectionSocket= obj asSocket;
  88. if(ConnectionSocket==null)
  89. {
  90. return;
  91. }
  92. while(true)
  93. {
  94. //接收客户端发来信息
  95. byte[] buffer =newbyte[1024*1024*2];
  96. //实际接收的有效字节数
  97. int receiveIndex =ConnectionSocket.Receive(buffer);
  98. //以实际接收有效字节数来判断客户端是否下线了
  99. if(receiveIndex ==0)
  100. {
  101. break;
  102. }
  103. string str =Encoding.UTF8.GetString(buffer,0, buffer.Length);
  104. ReceiveMsg.Text+= str +"\r\n";
  105. }
  106. }
  107. /// <summary>
  108. /// 服务端发送消息
  109. /// </summary>
  110. publicvoidServerSendMessage()
  111. {
  112. byte[] buffer =Encoding.UTF8.GetBytes(SendMessage.Text);
  113. int connectionIndex =ConnectionSocket.Send(buffer);
  114. }
  115. }
  116. }

二、客户端代码

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Net;
  5. using System.Net.Sockets;
  6. using System.Text;
  7. using System.Threading;
  8. using System.Threading.Tasks;
  9. using System.Windows.Forms;
  10. namespace 网络编程.SockteHandle
  11. {
  12. /// <summary>
  13. /// 客户端
  14. /// </summary>
  15. publicclassClientHandle
  16. {
  17. /// <summary>
  18. /// IP地址
  19. /// </summary>
  20. publicstaticstringConnectionIp{ get;set;}
  21. /// <summary>
  22. /// 端口号
  23. /// </summary>
  24. publicstaticstringPoint{ get;set;}
  25. //发送消息
  26. publicTextBoxSendMsg{ get;set;}
  27. /// <summary>
  28. /// 接收消息
  29. /// </summary>
  30. publicTextBoxReciveMsg{ get;set;}
  31. /// <summary>
  32. /// 客户端Socket对象
  33. /// </summary>
  34. publicSocket socketSend =null;
  35. /// <summary>
  36. /// 创建负责通信的Socket
  37. /// </summary>
  38. publicvoidCreateClientSocket()
  39. {
  40. socketSend =newSocket(AddressFamily.InterNetwork,SocketType.Stream,ProtocolType.Tcp);
  41. IPAddress ip =IPAddress.Parse(ConnectionIp);
  42. IPEndPoint endPoint =newIPEndPoint(ip,Convert.ToInt32(Point));
  43. socketSend.Connect(endPoint);
  44. ReciveMsg.Text+="连接到服务器";
  45. //创建一个线程来接收服务器端数据
  46. Thread reciveThread =newThread(ReciveServerMessage);
  47. reciveThread.IsBackground=true;
  48. reciveThread.Start(socketSend);
  49. }
  50. /// <summary>
  51. /// 接收服务端信息
  52. /// </summary>
  53. voidReciveServerMessage(object obj)
  54. {
  55. Socket reciveSocket = obj asSocket;
  56. while(true)
  57. {
  58. byte[] buffer =newbyte[1024*1024*2];
  59. int reciveIndex = reciveSocket.Receive(buffer);
  60. if(reciveIndex ==0)
  61. {
  62. break;
  63. }
  64. ReciveMsg.Text+="\r\n"+Encoding.UTF8.GetString(buffer)+"\r\n";
  65. }
  66. }
  67. /// <summary>
  68. /// 发送消息
  69. /// </summary>
  70. publicvoidSendMessage()
  71. {
  72. byte[] buffer =Encoding.UTF8.GetBytes(SendMsg.Text);
  73. int sendIndex = socketSend.Send(buffer);
  74. }
  75. }
  76. }
 

C#中网络通信的更多相关文章

  1. RocketMq中网络通信之服务端

    一,Broker服务端入口(NettyServer端) 首先RocketMq网络通信采用的Netty通信.服务端主要集中在Broker中.我们先看一下Broker的启动类BrokerStartup 显 ...

  2. Linux中网络通信中 使用的结构体

    "+++++++++++++++++++++++++ Linux TCP/UDP通信中的结构体 +++++++++++++++++++++++++++++++++++++++" s ...

  3. java中网络通信 Scoket

    在客户/服务器通信模式中,客户端需要主动建立与服务器连接的Socket,服务器端收到客户端的连接请求,也会创建与客户端连接的Socket.Socket可以看做是通信连接两端的收发器,客户端和服务店都通 ...

  4. Linux下UPnP sample分析

        一.UPnP简介   UPnP(Universal Plug and Play)技术是一种屏蔽各种数字设备的硬件和操作系统的通信协议.它是一种数字网络中间件技术,建立在TCP/IP.HTTP协 ...

  5. python高级之网络编程

    python高级之网络编程 本节内容 网络通信概念 socket编程 socket模块一些方法 聊天socket实现 远程执行命令及上传文件 socketserver及其源码分析 1.网络通信概念 说 ...

  6. android考试题

    一.选择题 1. Math.round(11.5)等于多少(    ). Math.round(-11.5) 等于多少(   C  ). A.11 ,-11    B.11 ,-12 C.12 ,-1 ...

  7. 第六篇:python高级之网络编程

    python高级之网络编程   python高级之网络编程 本节内容 网络通信概念 socket编程 socket模块一些方法 聊天socket实现 远程执行命令及上传文件 socketserver及 ...

  8. ZooKeeper 03 - ZooKeeper集群的脑裂问题 (Split Brain问题)

    目录 1 ZooKeeper的主从机制 2 什么是ZooKeeper的脑裂 2.1 脑裂现象的表现 2.2 为什么会出现脑裂 3 ZooKeeper如何解决"脑裂" 3.1 3种可 ...

  9. JAVA自学笔记26

    JAVA自学笔记26 1.网络编程 1)用来实现网络互联的不同计算机上运行的程序可以进行数据交换 2)网络模型一般泛指 OSI:(Open System Interconnection)开放系统互联参 ...

随机推荐

  1. vim 常用操作笔记

    跳转最后一行 :$ 或 shift+g 跳转第一行 :1 或 gg 设置自动换行 :set wrap 设置不自动换行 :set nowrap

  2. hiho1804 - 整数分解、组合数、乘法逆元

    题目链接 题目叙述很啰嗦,可以简化为:n个球[1-1e5],放到m个不同的桶里,一共多少种不同的放法.[桶里可以不放] ---------------------------------------- ...

  3. 3D集合图元:最小边界框/包围盒(boundingbox)

    对于2D边界框的应用时比较广泛地,它为一个简单匹配建立了很小的计算规则,3D模型的boundingbox则比较困难,计算代价较大.对于PCL库的使用则降低了计算难度,三维数值化降低了建模过程,可以使用 ...

  4. Python代码块缓存、小数据池

    引子 前几天遇到了这样一道Python题目:a='123',b='123',下列哪个是正确的? A. a != b B. a is b C. a==123 D. a + b =246 正确答案是B 是 ...

  5. Javase范式

    package Xwxx; import java.util.ArrayList; import java.util.Iterator; import java.util.function.IntBi ...

  6. 阿里云API网关!

    API 网关(API Gateway)提供高性能.高可用的 API 托管服务,帮助用户对外开放其部署在 ECS.容器服务等阿里云产品上的应用,提供完整的 API 发布.管理.维护生命周期管理.用户只需 ...

  7. mysql备份脚本二(带日志)

    #!/bin/bashdb_PATH='/shareSAN/mysqldata/ocs/mysql_back_wjf' #备份文件保存的路径#db_DBNAME='sz_ocs' #备份的数据库名db ...

  8. 网络教程(2)光纤和RF编码简介

    光纤: 想象一个symbol是light off 另一个是light on 另一种传输信息的方式using radio waves(无线电波: 这个router 内部以很高的频率变换电压 (例如2.4 ...

  9. MPlayer 开始支持RTSP/RTP流媒体文件

    hostzhu点评:MPlayer对流媒体的支持,让大家能更进一步地利用linux来看网络直播,对Linux下多媒体应用的推动作用可以说不可度量. RTSP/RTP streaming support ...

  10. Spring环境搭建及简单demo

    1. Spring框架简介(以下这段话可用于面试求职) Spring为JavaEE开发提供了一个轻量级的解决方案,主要表现为, IOC(或者叫做DI)的核心机制,提供了bean工厂(Spring容器) ...