使用C#进行点对点通讯和文件传输(发送接收部分)

2023-05-16

上面介绍了通讯的基类,下面就是使用那个类进行发送和接收的部分:

二、发送部分:

发送咱们使用了多线程,可以同时进行多个任务,比如发送文件、发送文本等,互不影响:

发送文本方法:

private void StartSendText(string strHost,int iPort,string strInfo)

       {

           SendText stText = new SendText(strHost,iPort,strInfo,new CommunClass.OnSend(OnSendDrawProgress)) ;

           StartThread(new ThreadStart(stText.Send)) ;

       }

下面是他调用用到的一些方法:

开始一个线程

private void StartThread(ThreadStart target)

       {

           Thread doStep = new Thread(target) ;          

           doStep.IsBackground = true ;

           doStep.Start() ;

       }

 发送一部分(本文设置的是1024字节)成功后的回调方法

        public void OnSendDrawProgress(int iTotal,int iSending)

       {  

           if (iTotal != pbMain.Maximum)

               pbMain.Maximum = iTotal ;

                pbMain.Value = iSending ;

       }

因为使用的是线程,所以发送文本使用的是一个发送文本类的方法,该类如下:

public class SendText

     {

          private string Host ;

          private int Port ;

          private string Info ;

          private CommunClass.OnSend onsend ;

         public SendText(string strHost,int iPort,string strInfo,

              CommunClass.OnSend onSend)

         {

              Host = strHost ;

              Port = iPort ;

              Info = strInfo ;

              onsend = onSend ;

         }

         public void Send()

         {

              Socket s  = null ;

              try

              {

                   s = CommunClass.ConnectToServer(Host,Port) ;

 

                   CommunClass.WriteCommandToSocket(s,"SENDTEXT") ;

                   CommunClass.WriteCommandDescToSocket(s,"") ;                  

                   CommunClass.WriteDynamicTextToSocket(s,Info,onsend) ;

              }

              catch (Exception e)

              {

                   MessageBox.Show(e.Message) ;

              }

              finally

              {

                   if (s != null)

                        s.Close() ;

              }

         }

 

     }//end class

      

这样就可以使用一个线程发送文本了。

发送文件的方法也类似:

private void StartSendFile(string strHost,int iPort,string strFile)

       {

           SendFile sfFile = new SendFile(strHost,iPort,strFile,this.pbMain) ;

           pbMain.Value = 0 ;

           StartThread(new ThreadStart(sfFile.Send)) ;       

       }

发送文件的类:

public class SendFile

     {

          private string Host ;

          private int Port ;

          private string FileToSend ;

          private ProgressBar pbar;

 

         public SendFile(string strHost,int iPort,string strFile,ProgressBar pbMain)

         {

              Host = strHost ;

              Port = iPort ;

              FileToSend = strFile ;

              pbar = pbMain ;

         }

         public void Send()

         {

              Socket s  = null ;

              try

              {                  

                   s = CommunClass.ConnectToServer(Host,Port) ;

 

                   CommunClass.WriteCommandToSocket(s,"SENDFILE") ;

                   CommunClass.WriteCommandDescToSocket(s,"") ;

                  

                   CommunClass.WriteFileToSocket(s,FileToSend,new CommunClass.OnSend(OnSendDrawProgress)) ;

              }

              catch (Exception e)

              {

                   MessageBox.Show(e.Message) ;

              }

              finally

              {

                   if (s != null)

                        s.Close() ;

              }

         }

        

 

         public void OnSendDrawProgress(int iTotal,int iSending)

         {   

              if (iTotal != pbar.Maximum)

                   pbar.Maximum = iTotal ;

           

              pbar.Value = iSending ;

         }        

    

     }//end class

当然,你发送一个命令让服务器端启动一个程序(靠,这不成木马了吗?)也可以:

俺这里只给出一部分代码,其余的您自己可以发挥以下:

public class ExeCuteFile

     {

          private string Host ;

          private int Port ;

          private string FileName ;

          private string cmdParam ;

        

         public ExeCuteFile(string strHost,int iPort,string strFileName,string strCmdParam)

         {

              Host = strHost ;

              Port = iPort ;

              FileName = strFileName ;

              cmdParam = strCmdParam ;

         }

        

         public void Send()

         {

                   Socket s  = null ;

              try

              {

                   s = CommunClass.ConnectToServer(Host,Port) ;

 

                   CommunClass.WriteCommandToSocket(s,"EXECUTEFILE") ;

                   CommunClass.WriteCommandDescToSocket(s,FileName) ;

                   CommunClass.WriteDynamicTextToSocket(s,"",null) ;

                   MessageBox.Show(CommunClass.ReadDynamicTextFromSocket(s)) ;

              }

              catch (Exception e)

              {

                   MessageBox.Show(e.Message) ;

              }

              finally

              {

                   if (s != null)

                        s.Close() ;

              }

 

         }

     }

三、下面是服务器端接受信息的代码:

创建监听:

/// <summary>

         /// 再给定的主机和端口上创建监听程序

         /// </summary>

         /// <param name="strAddress"></param>

         /// <param name="iPort"></param>

          private void BuildingServer(string strAddress,int iPort)

         {

              IPAddress ipAddress = Dns.Resolve(strAddress).AddressList[0];

             

              try

              {

                   listener =  new TcpListener(ipAddress, iPort);   

              }

              catch ( Exception e)

              {

                   AddInfo(e.Message) ;

              }

         }

开始监听:

/// <summary>

         /// 开始监听

         /// </summary>

          private void StartListen()

         {

              bool done = false;       

 

              listener.Start();

              while (!done)

              {

                   Socket s = listener.AcceptSocket() ;

                   if(s != null)

                   {

                        DealWithSocket dws = new DealWithSocket(s,this.tbLog) ;

                        StartThread(new ThreadStart(dws.DealWith)) ;

                   }

              }        

         }

 

private void StartThread(ThreadStart target)

         {

              Thread doStep = new Thread(target) ;

              doStep.IsBackground = true ;

              doStep.Start() ;

         }

 

 

开始监听后,对于每一个监听到的客户端的连接都用一个单独的线程来处理,处理通过类DealWithSocket来完成,下面是类代码:

public class DealWithSocket

     {

          private Socket s = null ;

          private TextBox tbLog = null ;

         public DealWithSocket(Socket newSocket,TextBox tbInfo)

         {

              s = newSocket ;

              tbLog = tbInfo ;

         }

 

         public void DealWith()

         {

              string strCmd = CommunClass.ReadCommandFromSocket(s) ;

              string strDesc = CommunClass.ReadCommandDescFromSocket(s) ;

              AddInfo(strCmd) ;

              switch(strCmd)

              {

                   case "SENDFILE" :

                        CommunClass.ReadDynamicFileFromSocket(s,"e://rrr.txt") ;                       

                       break ;

                   case "EXECUTEFILE" :

                       string strParam = CommunClass.ReadDynamicTextFromSocket(s) ;

                       string strResult = ExeCuteFile(strDesc,strParam) ;

                        CommunClass.WriteDynamicTextToSocket(s,strResult,null) ;

                       break ;

                   default:              

                       string strDetail = CommunClass.ReadDynamicTextFromSocket(s) ;

                        AddInfo(strDetail) ;

                       break ;

              }

              try

              {

                   s.Close() ;

              }

              catch (Exception e)

              {

                   AddInfo(e.Message) ;

              }

         }

          private void AddInfo(string strInfo)

         {

              string Info = DateTime.Now.ToLongTimeString() + " "+ strInfo +"/r/n" ;

              tbLog.Text += Info ;

              tbLog.Refresh() ;

         }

          private string ExeCuteFile(string strFileName,string strCmdParam)

         {

              System.Diagnostics.Process proc = new System.Diagnostics.Process() ;

              proc.StartInfo.FileName = strFileName ;

              proc.StartInfo.Arguments = strCmdParam ;

              try

              {

                   proc.Start() ;

                   return "OK" ;

              }

              catch(Exception err)

              {

                   return err.Message ;

              }

         }

     }//end class

以上就是所用的代码,希望大家批判指正.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用C#进行点对点通讯和文件传输(发送接收部分) 的相关文章

  • mysql 查看help手册

    作用 xff1a 解决 记得函数 xff0c 不记得语法的窘境 查看总的目录 mysql gt contents 其下的是各大分类 You asked for help about help category 34 Contents 34
  • vim 查看help命令

    并不需要查找vim 的工作手册 xff0c vim 自带说明书 步骤1 xff1a xff1a help 步骤2 xff1a quickref 步骤3 xff1a 找到 步骤4 xff1a ctrl键 键 同时按下 步骤5 xff1a 会来
  • ubuntu自带的命令查看

    xff1a man ls 比如查ls 命令
  • 【无标题】安装ROS E: 无法定位软件包 ros-melodic-desktop-full

    一 遇到问题 二 可能的原因和解决方法 1 源换一下 xff1a xff08 1 xff09 我是看这位大佬的 5条消息 记录 解决Ubuntu安装ros报错E Unable to locate package ros kinetic de
  • taskset命令:查看、指定进程运行在哪个cpu上

    reference xff1a https baijiahao baidu com s id 61 1592330790387359245 amp wfr 61 spider amp for 61 pc https www cnblogs
  • 超详细手把手教你四种方案彻底解决MAC npm install -g 报错permission denied

    在日常开发过程中 xff0c 我们使用MAC执行 npm install g 下载安装包的时候 xff0c 经常会遇到如下报错 xff1a permission denied 报错详情 xxx 64 CN C02xxxxx6M npm in
  • Ubuntu16.04 LTS 安装VNC Server开启远程桌面

    转载自http blog csdn net longhr article details 51657610 comments 查了各种博客 xff0c 有推荐XRDP的 xff0c 建议安装VNC的 xff0c 都不好用 xff0c 建议按
  • O2OA平台下载及安装部署

    平台下载及安装部署 O2OA安装部署非常方便 xff0c 只需要简单的三步即可完成安装 平台内部集成了多项管理命令 xff0c 可以进行系统升级 xff0c 管理员密码修改 xff0c 数据导出恢复等管理操作 一 下载安装包并且解压 安装包
  • 访问和操作H2数据库

    访问和操作H2数据库 O2OA平台内嵌了H2数据库 xff0c 管理员可以通过支持JDBC的客户端对H2数据库进行访问和数据操作 O2OA默认内嵌了H2数据库 xff0c H2数据库支持两种访问方式 xff1a 一 以WEB方式访问数据库
  • O2OA人员身份,人员属性

    人员信息创建 从组织管理应用中进入个人管理界面后 xff0c 点击左侧上方的添加按钮 xff0c 如下图所示 xff1a 在右侧显示的界面中填写人员信息 xff1a 人员名称 手机号码 唯一编码 xff08 以上必填 xff0c 其他选填写
  • O2OA的SSO与单点认证

    SSO与单点认证 与其他系统实现单点登入 1 1 URL传递加密参数方式 这种方式是比较通用简单的实现方式 xff0c 应急门户将用户登录信息 xff08 用户ID xff09 以URL参数方式传递给被集成系统 xff0c 被集成系统通过接
  • newman和Jenkins(postname和Jenkins的结合使用)

    Newman介绍 Newman 是 Postman 推出的一个 nodejs 库 xff0c 直接来说就是 Postman 的json文件可以在命令行执行的插件 Newman 可以方便地运行和测试集合 xff0c 并用之构造接口自动化测试和
  • SmartBI入门(一)介绍和安装

    一 SmartBI系统介绍 商业智能 xff08 Business Intelligence xff0c 简称 xff1a BI xff09 xff0c 又称商业智慧或商务智能 xff0c 指用现代数据仓库技术 线上分析处理技术 数据挖掘和
  • SmartBI入门(二)配置SmartBI

    具体可以参考文档 Smartbi Config页面介绍 Smartbi V10帮助中心 SmartBI配置 如果是首次访问 xff0c 需要设置 管理员账号 密码 xff0c 以便下次登录配置界面时验证 xff0c 设置后用用户名密码登录即
  • 求助 关于A-Frame带有动画模型的导入

    哪位大神知道导入带有动画的模型后 如何调用模型自带的动画 gltf格式的
  • SmartBI入门(三)数据源配置

    1 设置数据连接 配置连接 2 选择数据表 创建的数据源 xff0c 点击数据库管理 xff0c 添加实际报表需要的数据表 3 数据库展现
  • 再见2014,你好2015

    过去就是过去了 2014年再见 xff0c 2015年你好 xff01 回首 总结也只是慰藉 1999年12月至今 xff0c 经历了整整十五个曾经 xff0c 这其中的波折 xff0c 怎是我这样的小辈能够理解的 借这个平台也只是为了感谢
  • idea报错 Artifact web:war exploded: Error during artifact deployment. See server log for details.

    因为tomcat把报错信息重定向到日志文件中了 xff0c 所以在控制台找不到报错信息 所以需要看一下tomcat日志文件报错信息 xff0c 一般情况下都有报错 日志的路径默认是在C Users 你的用户名 AppData Local J
  • Unity离线用户手册打开缓慢、卡顿

    Unity中文离线用户手册下载页面 https docs unity3d com cn 2019 4 Manual OfflineDocumentation html 文档包下载地址 xff08 需要FQ xff09 https stora
  • Python MapReduce 案例

    map t py import sys import re p 61 re compile r 39 w 43 39 for line in sys stdin ss 61 line strip split 39 39 for s in s

随机推荐