局域网文件传输软件[通俗易懂]

局域网文件传输软件[通俗易懂]在公司实习了一个周,虽然很累,但也感觉有所得,此次项目是做一个局域网两台计算机之间的文件传输。我用的主要控件为winsock控件,用其TCP协议。至于用此控件连接两台计算机书上都有介绍,我主要介绍一下我传送文件的思想和方法:首先,将要传送的文件分成指定大小的N个包,大小不能超过8K因为TCP每次最多发送8K数据,最后一个包可能会小于其它包。然后在每个包加个包头,因为接收端需要通过包头知道传送过来的

大家好,又见面了,我是你们的朋友全栈君。在公司实习了一个周,虽然很累,但也感觉有所得,此次项目是做一个局域网两台计算机之间的文件传输。我用的主要控件为winsock控件,用其TCP协议。至于用此控件连接两台计算机书上都有介绍,我主要介绍一下我传送文件的思想和方法:

首先,将要传送的文件分成指定大小的N个包,大小不能超过8K因为TCP每次最多发送8K数据,最后一个包可能会小于其它包。然后在每个包加个包头,因为接收端需要通过包头知道传送过来的是数据还是路径(因为发送端指定存放路径),接收端收到数据后必须返回确认到发送端,这样才能循环发送,但一定要有最后的终止,不然会死循环。我的主要发送和接收代码如下:

发送端收到数据后产生的事件

Private Sub WskCli_DataArrival(ByVal bytesTotal As Long)

    Dim FIT As Boolean, OVER As Boolean, xx As Byte

    WskCli.GetData FIT

    If Number < BagNum Then

        If FIT = True Then ‘接收端已收到上一个数据包

           

            If v <> 0 Then ‘传送速率受限制

                Dim ss As Long

                ss = 0

                Do Until (Number * 1024 <= v * ss) ‘传送速率过大则等待

                    ss = CLng((Time – timeInt) * 3600 * 24)

                Loop

            End If

           

            Send_File ‘调用发送文件数据包过程

        End If

        Number = Number + 1 ‘计数

        ProgressBar1.Value = Number * 20 / BagNum ‘刷新进度条的进度

    El**

        *x = 2

        WskCli.SendData xx ‘发送传送完毕的信息给接收端

        Close 1

        Label1.Caption = “发送完毕!”

        OVER = True

        Number = 0 ‘传送完后置计数Number=0

    End If

    If OVER = True Then ‘传送完之后的处理

        Drive1.Enabled = True

        Dir1.Enabled = True

        File1.Enabled = True

        CmdSend.Enabled = True

        Exit Sub

    End If

End Sub

send_file是自定义的一个发送过程:

Private Sub Send_File()

    Dim i As Long ‘循环变量

    If Number <= BagNum – 1 Then

        ReDim Buff(1 To BagSize) As Byte ‘定义缓冲区

        ReDim TempBuff(0 To BagSize) As Byte

       

        Get 1, , Buff

       

        TempBuff(0) = 1 ‘设置包头为1代表文件数据

        For i = 1 To BagSize

            TempBuff(i) = Buff(i)

        Next

       

        WskCli.SendData TempBuff

    Else

        ‘传送最后一个数据包

        n = filelength – Seek(1) + 1 ‘得到最后一个包的大小

        If n > 0 Then

            ReDim Buff(0 To n) As Byte

            ReDim TempBuff(0 To n) As Byte

            TempBuff(0) = 1 ‘设置包头为1代表文件数据

            Get 1, , Buff

            For i = 1 To n

                TempBuff(i) = Buff(i – 1)

            Next

            WskCli.SendData TempBuff

        End If

    End If

End Sub

‘发送按钮被按下的响应事件

Private Sub CmdSend_Click()

    CmdSend.Enabled = False

    Combo1.Enabled = False

    If Combo1.Text = “” Then

        MsgBox “请选择一个传输速度!”, vbOKOnly, “错误”

    Else

        ‘传送速度的选择

        Select Case Combo1.ListIndex

            Case 0

                v = CLng(200) * 1024

            Case 1

                v = CLng(600) * 1024

            Case 2

                v = 1.5 * CLng(1024) * 1024

            Case 3

                v = 2 * CLng(1024) * 1024

            Case 4

                v = 0

        End Select

        If Number > 0 Then

            ‘重传或续传

            If MsgBox(“上次未能传送完成,是否续传?”, vbYesNo, “提示”) = vbNo Then Number = 0: Close 1

        End If

       

        ReDim Buff(Len(sendFileName)) As Byte

        Buff(0) = 0

        For i = 1 To Len(sendFileName)

            Buff(i) = Asc(Mid(sendFileName, i, 1))

        Next

        WskCli.SendData Buff ‘发送文件路径和文件名

    End If

    Open fn For Binary Access Read As #1

   

    ‘设置数据包的数量

    filelength = LOF(1) ‘文件长度

    BagNum = filelength / BagSize

    If BagNum < filelength / BagSize Then BagNum = BagNum + 1

   

    ‘计时初始化

    timeInt = Time

End Sub

接收端接收数据的事件:

Private Sub WskSer_DataArrival(ByVal bytesTotal As Long)

    Dim Buff() As Byte ‘定义接收数据缓冲区

    Dim OVER As Boolean ‘结束标记

   

    WskSer.GetData Buff ‘接收数据

   

    ‘判断包头信息

    Select Case Buff(0) ‘包头

        Case 0

            ‘得到存放路径和文件名

            fn = “”

            For i = 1 To UBound(Buff)

                fn = fn + Chr(Buff(i))

            Next

           

            Open fn For Binary As #1 ‘新建或打开文件

            Close 1

            Label1.Caption = “正在发送”

        Case 1

            ‘写入文件

            Open fn For Binary Access Write As #1

            Seek #1, LOF(1) + 1 ‘找到文件尾

            ReDim TempBuff(1 To UBound(Buff)) As Byte

           

            ‘去掉包头

            For i = 1 To UBound(Buff)

                TempBuff(i) = Buff(i)

            Next

           

            Put 1, , TempBuff ‘将数据写入文件

            Close 1

        Case 2

            ‘接收结束

            Label1.Caption = “发送完毕!”

            OVER = True

    End Select

   

    If OVER = True Then Exit Sub ‘如果接收完毕则退出此过程

    WskSer.SendData True ‘告诉客户端继续发送下一个数据包

End Sub

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135923.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • eplan激活码分享【最新永久激活】

    (eplan激活码分享)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html70YZDJVTFP-eyJsaWNlbnNlSW…

    2022年3月26日
    3.7K
  • SM8S33、TVS瞬态抑制二极管在汽车上的问题与应用

    SM8S33、TVS瞬态抑制二极管在汽车上的问题与应用随着经济的发展,现代汽车工业也在的高速发展,汽车的电子化、数字化、自动化、通讯化、自动驾驶等相关模块的成为汽车行主流方向;于此同时系统之间的EMC电磁兼容就显得尤为重要,我们专门为电气化的设计提供了高效的保护方案与应用!汽车电源系统的应用:1.首先了解一下基本情况:虽然高浪涌电压是汽车电路保护系统的应对对象,但是也要注意钳位的电压高度。电源系统,12V与24V的电池在指定的环境下最大输出电压的值。常见的稳压器和DC-DC转换器IC的最大输入电压的值。EMC电磁问题的解决,汽车电子系统是干扰源复杂

    2022年9月23日
    4
  • navicate 15.0.23激活码【注册码】

    navicate 15.0.23激活码【注册码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月17日
    49
  • pycharm如何配置git_网络设备配置基础实训总结

    pycharm如何配置git_网络设备配置基础实训总结PyCharm与Github配置使用总结

    2022年8月27日
    4
  • css两端对齐IOS不适用 样式冲突

    css两端对齐IOS不适用 样式冲突问题 textclass explain v html info goodsExplain explain white space pre wrap 用来换行 display inline block text align justify 用来两端对齐 text align last left word break break word 文本带有换行符 没有带标签 textclass explain v html info goodsExplain

    2025年7月27日
    1
  • vmware虚拟机重装系统_ubuntu下安装虚拟机

    vmware虚拟机重装系统_ubuntu下安装虚拟机VMware下载地址:https://www.vmware.com/products/workstation-pro/workstation-pro-evaluation.html下载之后按步骤安装即可。安装完成后需要密钥,这里给出VMwareWorkstationPro16的密钥:YF390-0HF8P-M81RQ-2DXQE-M2UT6ZF71R-DMX85-08DQY-8YMNC-PPHV8密钥输入完成就可永久使用。ubuntu:首先下载Ubuntu的镜像,我下载的是ubuntu

    2022年9月14日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号