C#串口通信—传输文件测试

说明:该程序可能不具备实用性,仅测试用。

一、使用虚拟串口工具VSPD虚拟两个串口COM1和COM2

二、约定

占一个字节,代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace COMClient
{
    /// <summary>
    /// 约定
    /// </summary>
    public enum Protocol
    {
        Client端发送文件名 = 0,
        Client端发送数据块 = 1,
        Client端发送最后一个数据块 = 2,

        Server端本次接收完毕 = 3,
        Server端结束 = 4
    }
}

三、功能说明:

COMClient程序监听COM1串口,COMServer程序监听COM2串口。COMClient先择文件,发送,COMServer接收文件。数据分多次发送,每次发送的数据,通过第一个字节判断发送的这段数据是干啥的,后面的字节是数据本身。

四、COMClient端发送文件

代码:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO.Ports;
using System.IO;
using System.Threading;

namespace COMClient
{
    public partial class Form1 : Form
    {
        #region 变量
        /// <summary>
        /// 串口资源
        /// </summary>
        private static SerialPort serialPort = null;
        /// <summary>
        /// 文件
        /// </summary>
        private static FileStream fs = null;
        private static long index = 0;
        private static long blockCount;
        private static int size = 4095;
        private static DateTime dt;
        #endregion

        #region Form1
        public Form1()
        {
            InitializeComponent();
        }
        #endregion

        #region Form1_Load
        private void Form1_Load(object sender, EventArgs e)
        {
            serialPort = new SerialPort("COM1");
            serialPort.DataReceived += new SerialDataReceivedEventHandler(serialPort_DataReceived);
            serialPort.Open();
        }
        #endregion

        #region btnConn_Click
        private void btnConn_Click(object sender, EventArgs e)
        {
            if (openFileDialog1.ShowDialog() == DialogResult.OK)
            {
                dt = DateTime.Now;
                fs = new FileStream(openFileDialog1.FileName, FileMode.Open, FileAccess.Read);
                blockCount = (fs.Length - 1) / size + 1;

                List<byte> bList = new List<byte>();
                bList.Add((int)Protocol.Client端发送文件名);
                bList.AddRange(ASCIIEncoding.UTF8.GetBytes(openFileDialog1.FileName));
                byte[] bArr = bList.ToArray();
                serialPort.Write(bArr, 0, bArr.Length);
            }
        }
        #endregion

        /// <summary>
        /// 接收串口数据事件
        /// </summary>
        public void serialPort_DataReceived(object sender, SerialDataReceivedEventArgs e)
        {
            if (serialPort.BytesToRead == 0) return;

            int bt = serialPort.ReadByte();

            switch (bt)
            {
                case (int)Protocol.Server端本次接收完毕:
                    if (index != blockCount - 1)
                    {
                        byte[] bArr = new byte[size + 1];
                        bArr[0] = (int)Protocol.Client端发送数据块;
                        fs.Read(bArr, 1, size);
                        index++;
                        Thread.Sleep(1);
                        serialPort.Write(bArr, 0, bArr.Length);
                    }
                    else
                    {
                        byte[] bArr = new byte[fs.Length - (size * index) + 1];
                        bArr[0] = (int)Protocol.Client端发送最后一个数据块;
                        fs.Read(bArr, 1, bArr.Length - 1);
                        index++;
                        serialPort.Write(bArr, 0, bArr.Length);
                    }
                    break;
                case (int)Protocol.Server端结束:
                    index = 0;
                    double totalSeconds = DateTime.Now.Subtract(dt).TotalSeconds;
                    MessageBox.Show("完成,耗时" + totalSeconds + "秒,速度" + (fs.Length / 1024.0 / totalSeconds).ToString("#.0") + "KB/S");
                    fs.Close();
                    fs.Dispose();
                    break;
            }
        }

    }
}

五、COMServer端接收文件

代码:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO.Ports;
using System.IO;

namespace COMServer
{
    public partial class Form1 : Form
    {
        #region 变量
        /// <summary>
        /// 串口资源
        /// </summary>
        private static SerialPort serialPort = null;
        /// <summary>
        /// 文件
        /// </summary>
        private static FileStream fs = null;
        #endregion

        #region Form1
        public Form1()
        {
            InitializeComponent();
        }
        #endregion

        #region Form1_Load
        private void Form1_Load(object sender, EventArgs e)
        {
            serialPort = new SerialPort("COM2");
            serialPort.DataReceived += new SerialDataReceivedEventHandler(serialPort_DataReceived);
            serialPort.Open();
        }
        #endregion

        /// <summary>
        /// 接收串口数据事件
        /// </summary>
        public void serialPort_DataReceived(object sender, SerialDataReceivedEventArgs e)
        {
            if (serialPort.BytesToRead == 0) return;

            #region 接收数据
            int bt = serialPort.ReadByte();
            List<byte> bList = new List<byte>();
            while (serialPort.BytesToRead > 0)
            {
                byte[] bArr = new byte[serialPort.BytesToRead];
                serialPort.Read(bArr, 0, bArr.Length);
                bList.AddRange(bArr);
            }
            byte[] receiveData = bList.ToArray();
            #endregion

            switch (bt)
            {
                case (int)Protocol.Client端发送文件名:
                    string path = ASCIIEncoding.UTF8.GetString(receiveData);
                    string fileName = Path.GetFileName(path);
                    fs = new FileStream(@"d:\_临时文件\COM测试" + fileName, FileMode.Create, FileAccess.Write);
                    byte[] bArr = new byte[1];
                    bArr[0] = (int)Protocol.Server端本次接收完毕;
                    serialPort.Write(bArr, 0, bArr.Length);
                    break;
                case (int)Protocol.Client端发送数据块:
                    fs.Write(receiveData, 0, receiveData.Length);
                    fs.Flush();
                    bArr = new byte[1];
                    bArr[0] = (int)Protocol.Server端本次接收完毕;
                    serialPort.Write(bArr, 0, bArr.Length);
                    break;
                case (int)Protocol.Client端发送最后一个数据块:
                    fs.Write(receiveData, 0, receiveData.Length);
                    fs.Flush();
                    bArr = new byte[1];
                    bArr[0] = (int)Protocol.Server端结束;
                    serialPort.Write(bArr, 0, bArr.Length);
                    fs.Close();
                    fs.Dispose();
                    break;
            }
        }

    }
}

时间: 2024-08-26 16:08:17

C#串口通信—传输文件测试的相关文章

java socket通信-传输文件图片--传输图片

ClientTcpSend.java   客户端发送类 package com.yjf.test; import java.io.DataOutputStream; import java.io.File; import java.io.FileInputStream; import java.net.InetSocketAddress; import java.net.Socket; public class ClientTcpSend { public static String clien

C# 开发Modbus Rtu客户端 modbus测试Demo,Modbus 串口通信 , 虚拟MODBUS-RTU测试

前言 本文将使用一个NuGet公开的组件技术来实现一个ModBus RTU的客户端,方便的对Modbus rtu的服务器进行读写,这个服务器可以是电脑端C#设计的,也可以是PLC实现的,也可以是其他任何支持这个通信协议的服务器. github地址:https://github.com/dathlin/HslCommunication 如果喜欢可以star或是fork,还可以打赏支持. 在Visual Studio 中的NuGet管理器中可以下载安装,也可以直接在NuGet控制台输入下面的指令安装

ARM 开发板嵌入式linux系统与主机PC通过串口传输文件

本文转载自http://useless20.blog.163.com/blog/static/237409982010227127576/ 嵌入式linux系统与主机通过串口传输文件 我想如果要从PC机下载东西到开发板的嵌入式linux系统里面,很多人首先会想到用tftp sftp等网络工具从网口下载.但如果网络用不了,只能通过串口下载怎么办呢?这个时候有两个工具能帮到你:一个是zmrx.zmtx,另外一个是lsz.lrz.个人觉得zmrx/zmtx没有lsz/lrz稳定,建议还是用后者.下面介

串口传输文件 lrzsz

假设有一种开发环境,一块板子,除了串口,没有任何外部出入输出设备,没有sd卡,没有网线,这个时候如果你想跟这块板子传输交互文件,要怎么办? 根据modem所采用的文件传输协议:xmodem,ymodem,zmodem将其分类 xmodem:简单通用,传输信息单位是“包=128B”,传输速度慢,适合电话线路质量差的情况下用  ymodem:由XMODEM演变来,效率可靠性高,包=128*8B:一次传输可发送或接受几个文件 zmodem:于上两种不同,已连续的数据流发送数据,效率更高 在ubuntu

使用sz/rz基于串口传输文件

关键词:lrzsz.minicom.ZMODEM.MD5sum等. 在环境受限的嵌入式系统上,往往只有串口可以使用. 此时如果需要传输文件,需要借助rz/sz工具,可以使用的传输协议有ZMODEM.YMODEM.XMODEM,一般首选的是ZMODEM. 这里记录minicom下使用rz/sz进行文件传输的操作. 首先说明一下rz和sz的文件传输方向,这些命令都是在调试板上执行的,调试板通过串口和PC相连. rz表示调试版发起从PC接收文件,sz表示调试版发送向PC传送文件. 1. 使能sz/rz

串口通信依赖os文件

在Linux下开发与硬件串口通信时需共享库 librxtxSerial64.so 和librxtxSerial.so 放置java安装路径下的jre/lib/amd64目录下

VC++USB及串口通信程序(附工程)

为公司开发产品测试程序,实际上是基于VC++的USB通信及串口通信.当初编写程序时,网上找了很多资料及程序,感觉大都只是说了一点点,没有一个完整的工程以供其他开发者借鉴,完全要靠开发者东拼西凑,最后凑成一个整体工程,还要在这个工程基础上进行相当艰苦的排查问题.解决问题的调试过程.本人对这一过程极其厌烦,现将走完的以上的"艰苦历程"之后的成果列出,以供后来者借鉴. 这一工程中包含了以下知识点: 1. VC++ USB通信: 2. VC++串口通信: 3. 文件(设备)同步异步操作: 4.

串口通信IN C++(适用于Microsoft Visual Studio 2010/2012/2013 ,VC++6.0 )

                 向无数拼命工作的 程序猿 及 攻城狮 致敬! 软硬件平台简介 CPU:P4 2G及以上兼容于80x86架构的中央处理器 内存:1G及以上 硬盘:80G及以上 网卡:100M及以上 操作系统:Windows XP及以上 软件:VS2010/2012/2013  Visual C++ 6.0  Keil uVision3-4   STC_ISP_V488/友善串口助手 硬件:众多.不胜数 2.总体设计思想 串口通讯把数据的字节分解成单个的二进制比特流依次传输,其

Java串口通信详解(转)

Java串口通信详解(转) 作者:denimcc 日期:2007-05-11 序言    说到开源,恐怕很少有人不挑大指称赞.学生通过开源代码学到了知识,程序员通过开源类库获得了别人的成功经验及能够按时完成手头的工程,商家通过开源软件赚到了钱……,总之是皆大欢喜.然而开源软件或类库的首要缺点就是大多缺乏详细的说明文档和使用的例子,或者就是软件代码随便你用,就是文档,例子和后期服务收钱.