CN105827700A - 一种动态文件的传输方法、装置及电子设备 - Google Patents
一种动态文件的传输方法、装置及电子设备 Download PDFInfo
- Publication number
- CN105827700A CN105827700A CN201610147622.6A CN201610147622A CN105827700A CN 105827700 A CN105827700 A CN 105827700A CN 201610147622 A CN201610147622 A CN 201610147622A CN 105827700 A CN105827700 A CN 105827700A
- Authority
- CN
- China
- Prior art keywords
- slicing files
- living document
- file
- operational order
- receiving terminal
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 230000005540 biological transmission Effects 0.000 title claims abstract description 85
- 238000000034 method Methods 0.000 title claims abstract description 59
- 238000004891 communication Methods 0.000 claims description 8
- 230000000052 comparative effect Effects 0.000 claims description 4
- 239000012634 fragment Substances 0.000 abstract description 14
- 230000006870 function Effects 0.000 description 24
- 238000013467 fragmentation Methods 0.000 description 5
- 238000006062 fragmentation reaction Methods 0.000 description 5
- 230000008569 process Effects 0.000 description 5
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- XLYOFNOQVPJJNP-UHFFFAOYSA-N water Substances O XLYOFNOQVPJJNP-UHFFFAOYSA-N 0.000 description 3
- 230000009471 action Effects 0.000 description 2
- 230000008901 benefit Effects 0.000 description 2
- 230000008878 coupling Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000003111 delayed effect Effects 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 238000009434 installation Methods 0.000 description 1
- 230000002045 lasting effect Effects 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 238000011084 recovery Methods 0.000 description 1
- 238000012559 user support system Methods 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/40—Support for services or applications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/104—Peer-to-peer [P2P] networks
- H04L67/1074—Peer-to-peer [P2P] networks for supporting data block transmission mechanisms
- H04L67/1078—Resource delivery mechanisms
- H04L67/108—Resource delivery mechanisms characterised by resources being split in blocks or fragments
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/004—Arrangements for detecting or preventing errors in the information received by using forward error control
- H04L1/0056—Systems characterized by the type of code used
- H04L1/0057—Block codes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/06—Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
- H04L9/3236—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions
- H04L9/3239—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions involving non-keyed hash functions, e.g. modification detection codes [MDCs], MD5, SHA or RIPEMD
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- Multimedia (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明实施例公开了一种动态文件的传输方法、装置及电子设备,所述方法包括:获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端;根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容;对所述动态文件I进行实时分片,依次获取多个分片文件;使用喷泉码对已获取的所述分片文件进行编码;将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。本发明实施例提供的技术方案,通过将动态文件进行分片得到分片文件,以及将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端的方式,缩短了动态文件的传输时间。
Description
技术领域
本发明涉及数据传输技术领域,尤其涉及一种动态文件的传输方法、装置及电子设备。
背景技术
目前,发送端和接收端之间传输动态文件采用的方法是:发送端在动态文件创建完成之后才将获取的动态文件传输到接收端。其中,动态文件是指文件从开始创建到创建完成有一个持续的过程,在创建过程中文件内容不断更新的文件,比如实时获取的视频文件、或者实时获取的音频文件等。
本发明的发明人在研究和实践过程中发现,由于动态文件具有容量大,持续时间长的特点,目前采用的传输方法,从动态文件开始创建到创建完毕、以及再到接收端接收全所述创建完毕的动态文件存在较长时间的滞后。因此,现有技术不利于接收端及时获取发送端创建的动态文件。另外,目前网络状态通常不够稳定,在传输大容量的动态文件时,容易由于网络状态不佳,导致传输失败,这时发送端需要重新向接收端传输动态文件,这将进一步延长从发送端开始创建动态文件到接收端获得完整的动态文件的时间。
发明内容
本发明实施例提供了一种动态文件的传输方法、装置及电子设备,可以解决如何缩短动态文件传输时间的问题。
本发明实施例第一方面提供一种动态文件的传输方法,包括:
获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端;
根据所述第一操作指令所述创建动态文件I,并实时更新所述动态文件I的内容;
对所述动态文件I进行实时分片,依次获取多个分片文件;
使用喷泉码对已获取的所述分片文件进行编码;
将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
结合第一方面,在第一方面的第一种可能的实施方式中,在对所述动态文件I进行实时分片之后,所述方法还包括:
使用散列函数对分片文件Ij进行计算,得到与所述分片文件Ij对应的第一哈希值SHA2j,所述分片文件Ij为对所述动态文件I进行实时分片后获取的第j个分片文件,所述j为大于或者等于1的整数;
生成与所述分片文件Ij对应的分片文件信息记录Lj,所述分片文件信息记录Lj保存在分片文件信息配置表P中,所述分片文件信息记录Lj中记录了所述分片文件Ij的位置信息和所述第一哈希值SHA2j。
结合第一方面的第一种可能的实施方式,在第一方面的第二种可能的实施方式中,在所述根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容之后,所述方法还包括:
获取第二操作指令,所述第二操作指令用于指示所述动态文件I创建完成;
在获取所述第二操作指令之后,所述方法还包括:
使用散列函数对所述分片文件Ij重新进行计算,得到与所述分片文件Ij对应的第二哈希值SHA2j';
比较所述第一哈希值SHA2j和所述第二哈希值SHA2j'是否相同;
在所述第一哈希值SHA2j不同于所述第二哈希值SHA2j'的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端。
结合第一方面的第二种可能的实施方式,在第一方面的第三种可能的实施方式中,在获取所述第二操作指令之后,以及对所述动态文件I进行实时分片结束之后,所述方法还包括:
向所述接收端发送所述分片文件信息配置表P,以使所述接收端根据所述分片文件信息配置表P将接收到的文件进行合并。
结合第一方面的第一种可能的实施方式,在第一方面的第四种可能的实施方式中,在对所述动态文件I进行实时分片之后,所述方法还包括:
生成分片文件信息队列,所述分片文件信息队列记录了每个分片文件的文件传输状态,在所述分片文件信息队列中记录的所述分片文件Ij的文件传输状态为传输失败的情况下,将使用喷泉码对所述分片文件Ij进行编码后得到的文件重新传输到接收端。
结合第一方面或第一方面的第一种可能的实施方式或第一方面的第二种可能的实施方式或第一方面的第三种可能的实施方式或第一方面的第四种可能的实施方式,在第一方面的第五种可能的实施方式中,所述使用喷泉码对已获取的所述分片文件进行编码,包括:
使用Raptor编码对已获取的所述分片文件进行编码。
本发明实施例第二方面提供一种动态文件的传输装置,包括:
第一获取单元,用于获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端;
创建单元,用于根据所述第一获取单元获取的所述第一操作指令创建动态文件I,并实时更新所述动态文件I的内容;
分片单元,用于对所述创建单元创建的所述动态文件I进行实时分片,依次获取多个分片文件;
编码单元,用于使用喷泉码对所述分片单元对所述动态文件进行实时分片获取的所述分片文件进行编码;
第一传输单元,用于将所述编码单元使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
结合第二方面,在第二方面的第一种可能的实施方式中,所述传输装置还包括:
第一计算单元,用于在所述分片单元对所述动态文件I进行实时分片之后,使用散列函数对分片文件Ij进行计算,得到与所述分片文件Ij对应的第一哈希值SHA2j,所述分片文件Ij为对所述动态文件I进行实时分片后获取的第j个分片文件,所述j为大于或者等于1的整数。
第一生成单元,用于生成与所述分片文件Ij对应的分片文件信息记录Lj,所述分片文件信息记录Lj保存在分片文件信息配置表P中,所述分片文件信息记录Lj中记录了所述分片文件Ij的位置信息和所述第一哈希值SHA2j。
结合第二方面的第一种可能的实施方式,在第二方面的第二种可能的实施方式中,所述传输装置还包括:
第二获取单元,用于在所述创建单元根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容之后,获取第二操作指令,所述第二操作指令用于指示所述动态文件I创建完成。
第二计算单元,用于在所述第二获取单元获取所述第二操作指令之后,使用散列函数对所述分片文件Ij重新进行计算,得到与所述分片文件Ij对应的第二哈希值SHA2j'。
比较单元,用于比较所述第一哈希值SHA2j和所述第二哈希值SHA2j'是否相同。
第一处理单元,用于在所述比较单元的比较结果为所述第一哈希值SHA2j不同于所述第二哈希值SHA2j'的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端。
结合第二方面的第二种可能的实施方式,在第二方面的第三种可能的实施方式中,所述传输装置还包括
第二传输单元,用于在所述第二获取单元获取所述第二操作指令之后,以及所述分片单元对所述动态文件I进行实时分片结束之后,向所述接收端发送所述分片文件信息配置表P,以使所述接收端根据所述分片文件信息配置表P将接收到的文件进行合并。
结合第二方面的第一种可能的实施方式,在第二方面的第四种可能的实施方式中,所述传输装置还包括:
第二生成单元,用于在所述分片文件对所述动态文件I进行实时分片之后,生成分片文件信息队列,所述分片文件信息队列记录了每个分片文件的文件传输状态;
第三传输单元,用于在所述分片文件信息队列中记录的所述分片文件Ij的文件传输状态为传输失败的情况下,将使用喷泉码对所述分片文件Ij进行编码后得到的文件重新传输到接收端。
结合第二方面或第二方面的第一种可能的实施方式或第二方面的第二种可能的实施方式或第二方面的第三种可能的实施方式或第二面的第四种可能的实施方式,在第一方面的第五种可能的实施方式中,所述编码单元具体用于,使用Raptor编码对已获取的所述分片文件进行编码。
本发明实施例第三方面提供一种电子设备,包括:处理器、存储器、通信接口和总线;
所述处理器、所述存储器和所述通信接口通过所述总线连接并完成相互间的通信;
所述存储器存储可执行程序代码;
所述处理器通过读取所述存储器中存储的可执行程序代码来运行与所述可执行程序代码对应的程序,以用于执行一种动态文件的传输方法;其中,所述动态文件的传输方法包括:
获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端;
根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容;
对所述动态文件I进行实时分片,依次获取多个分片文件;
使用喷泉码对已获取的所述分片文件进行编码;
将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
本发明实施例第四方面提供一种存储介质,其中,该存储介质用于存储应用程序,所述应用程序用于在运行时执行本发明实施例所述的一种动态文件的传输方法。
本发明实施例第五方面提供一种应用程序,其中,该应用程序用于在运行时执行本发明实施例所述的一种动态文件的传输方法。
可以看出,采用本发明实施例提供的技术方案,在进行动态文件传输时,通过先将动态文件进行分片得到小的分片文件,可以减少由于网络故障导致整个文件重新传输的概率,另外,通过将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端,可以加快文件的传输速度,因此采用本发明提供的技术方案缩短了动态文件的传输时间。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明实施例提供的一种网络架构的示意图;
图2是本发明的实施例提供的一种动态文件的传输方法的流程示意图;
图3是本发明的另一实施例提供的一种动态文件的传输方法的流程示意图;
图4是本发明的另一实施例提供的一种动态文件的传输方法的流程示意图;
图5是本发明的另一实施例提供的一种动态文件的传输方法的流程示意图;
图6是本发明实施例提供的一种动态文件的传输装置的结构示意图;
图7是本发明的另一实施例提供的一种动态文件的传输装置的结构示意图;
图8是本发明的另一实施例提供的一种动态文件的传输装置的结构示意图;
图9是本发明的另一实施例提供的一种电子设备的结构示意图。
具体实施方式
本发明实施例提供了一种动态文件的传输方法、装置及电子设备,能够缩短动态文件的传输时间。
为了使本技术领域的技术人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
以下分别进行详细说明。
本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”、“第三”和“第四”等是用于区别不同对象,而不是用于描述特定顺序。此外,术语“包括”和“具有”以及它们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤或单元的过程、方法、***、产品或设备没有限定于已列出的步骤或单元,而是可选地还包括没有列出的步骤或单元,或可选地还包括对于这些过程、方法、产品或设备固有的其它步骤或单元。
本发明一种动态文件的传输方法,可以包括:获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端;根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容;对所述动态文件I进行实时分片,依次获取多个分片文件;使用喷泉码对已获取的所述分片文件进行编码;将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
请参阅图1,图1是一种可能用于实施本发明实施例方案的网络架构。在图1所示的网络架构中,包括:发送端和至少一个接收端,发送端用于获取动态文件和将获取的动态文件通过网络传输到接收端。其中,动态文件可以是发送端实时获取的视频文件或者实时获取的音频文件,发送端可以为智能手机、笔记本电脑、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、导航装置等具备拍摄视频或获取视频或录音等功能且能够访问网络的电子装置;接收端可以为云服务器、智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具有通过网络接收数据、并能够反馈数据接收状态的电子设备,本发明实施例不作限定。
其中,发送端获取动态文件后根据文件分片策略将已获取的动态文件进行分片,比如可以按照预设的大小进行分片,举例来说,可以按照10M的大小将动态文件进行分片,即将开始获取动态文件到动态文件更新到10M时的文件片段作为第一分片文件,当动态文件更新到20M时,可以将10M至20M之间的文件片段作为第二个分片文件。当然也可以按照预设的时间间隔对动态文件进行分片,举例来说,若动态文件为实时增加的视频文件时,则可以设置每隔两秒钟对动态文件进行分片,即将0秒至2秒之间的视频片段作为第一分片文件,将2秒至4秒之间的视频片段作为第二分片文件。在发送端将动态文件进行分片后,对分片文件使用喷泉码进行编码,然后将编码后的文件传输到接收端。
喷泉码是1998年由M.Luby等人提出的编码方法,喷泉码的编码类似于一个喷泉,若用一个水杯接收,只要接收到足够多的水即可,而不关心接到的是哪几滴水或接到的水的顺序,就是这种类似喷泉的编码特性,将这种编码方式命名为喷泉码,喷泉码的基本思想是,发送端如喷泉一样源源不断地产生编码数据包,接收端只要接收到足够的数据包就能成功恢复原始数据,编码数据包被接收的顺序对译码没有影响。
喷泉码有LT编码和Raptor编码两种,Raptor编码是在LT编码基础上的改进得到的编码,它的提出是因为LT编码中存在用于保证对输入数据包良好覆盖的少量较大的包,这些包增加了译码过程中异或操作的次数,降低了可译几何的比例,降低了译码的成功率。Raptor编码具有无固定码率、无需反馈、低编译码复杂度、对异质用户支持友好(不同用户所处的网络环境不尽相同,用户只要根据自己的网络状况接收编码数据包进行译码即可)、以及有利于并行下载和多远下载等多重优势,所以Raptor编码应用在具有大数据量的多媒体数据的多播推送中,能更好地解决数据传输中存在的技术弊端,更好地发挥多播推送服务的优势,有利于加快数据从发送端到接收端的传输速度,节省数据从发送端到接收端的传输时间。
若发送端为手机,通过点击手机中的应用,实时地拍摄视频,采用本发明提供的技术方案,视频在拍摄过程中,对已获取的视频文件进行分片,即获得小容量的分片文件,然后对每个分片文件进行Raptor编码,将Raptor编码后的文件传输到接收端,接收端可以根据接收到的分片文件编码后的文件后经过译码得到分片文件、以及根据分片文件得到发送到获取的动态文件。
本发明实施例提供的技术方案,一方面,通过将动态文件进行分片,降低了当网络不稳定时大文件易受影响而重传的概率;另一方面,通过将分片文件进行Raptor编码后传输到接收端,加快了动态文件的传输,有利于接收端及时获取动态文件。
请参阅图2,图2是本发明的一个实施例提供的一种动态文件的传输方法的流程示意图,如图2所示,本发明的一个实施例提供的一种动态文件的传输方法可以包括以下内容:
201、发送端获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端。
其中,发送端用于获取动态文件和将获取的动态文件通过网络传输到接收端。发送端可以为智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具备拍摄视频或获取视频或录音等功能且能够访问网络的电子设备。
其中,动态文件可以是发送端实时获取的视频文件或者实时获取的音频文件。
其中,接收端可以为云服务器、智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具有通过网络接收数据、并能够反馈数据接收状态的电子设备,本发明实施例不作限定。
202、发送端根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容。
举例来说,若第一操作指令为录像指令、并指示将录像文件发送到接收端,则动态文件I为视频文件,则发送端在获取第一操作指令后,创建视频文件,并且实时更新录像文件,直至获取到用于指示动态文件I创建完成的第二操作指令,才结束对动态文件I的更新。
203、发送端对所述动态文件I进行实时分片,依次获取多个分片文件。
其中,发送端获取动态文件后可以根据文件分片策略将已获取的动态文件进行分片,比如可以按照预设的大小进行分片,举例来说,可以按照10M的大小将动态文件进行分片,即:将开始获取动态文件到动态文件更新到10M时的文件片段作为第一分片文件,当动态文件更新到20M时,可以将10M至20M之间的文件片段作为第二个分片文件,以此类推对获取的动态文件进行实时分片。当然也可以按照预设的时间间隔对动态文件进行分片,举例来说,若动态文件为实时增加的视频文件,可以设置每隔两秒钟对动态文件进行分片,即:将0秒至2秒之间的视频片段作为第一分片文件,将2秒至4秒之间的视频片段作为第二分片文件,以此类推对获取的动态文件进行实时分片。在发送端将动态文件进行分片后,对分片文件使用喷泉码进行编码,然后将编码后的文件传输到接收端。
204、发送端使用喷泉码对已获取的所述分片文件进行编码。
205、发送端将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
可选的,在本发明一些可能的实施方式中,可以使用Raptor编码对已获取的所述分片文件进行编码。
可以看出,采用本发明实施例提供的技术方案,在进行动态文件传输时,通过先将动态文件分片,得到小的分片文件,这样可以减少由于网络故障导致整个文件重新传输的概率;另外,通过将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端,可以加快文件的传输速度,因此采用本发明提供的技术方案缩短了动态文件的传输时间。
请参阅图3,图3是本发明的另一实施例提供的一种动态文件的传输方法的流程示意图,如图3所示,本发明的另一实施例提供的一种动态文件的传输方法可以包括以下内容:
301、发送端获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端。
其中,发送端用于获取动态文件和将获取的动态文件通过网络传输到接收端。发送端可以为智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具备拍摄视频或获取视频或录音等功能且能够访问网络的电子设备。
其中,动态文件可以是发送端实时获取的视频文件或者实时获取的音频文件。
其中,接收端可以为服务器、智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具有通过网络接收数据、并能够反馈数据接收状态的电子设备,本发明实施例不作限定。
302、发送端根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容。
举例来说,第一操作指令可以为录像指令、第一操作指令还用于指示将录像文件发送到接收端,则动态文件I为视频文件,则发送端在获取第一操作指令后,创建视频文件,并且实时更新录像文件,直至获取到用于指示动态文件I创建完成的第二操作指令,才结束对动态文件I的更新。
303、发送端对所述动态文件I进行实时分片,依次获取多个分片文件。
304、发送端使用散列函数对分片文件Ij进行计算,得到与所述分片文件Ij对应的第一哈希值SHA2j;所述分片文件Ij为对所述动态文件I进行实时分片后获取的第j个分片文件,所述j为大于或者等于1的整数。
305、发送端生成与所述分片文件Ij对应的分片文件信息记录Lj,所述分片文件信息记录Lj保存在分片文件信息配置表P中,所述分片文件信息记录Lj中记录了所述分片文件Ij的位置信息和所述第一哈希值SHA2j。
306、发送端使用喷泉码对已获取的所述分片文件进行编码。
307、发送端将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
308、发送端获取第二操作指令,所述第二操作指令用于指示所述动态文件I创建完成。
309、发送端使用散列函数对所述分片文件Ij重新进行计算,得到与所述分片文件Ij对应的第二哈希值SHA2j'。
310、发送端比较所述第一哈希值SHA2j和所述第二哈希值SHA2j'是否相同。
311、发送端在所述第一哈希值SHA2j不同于所述第二哈希值SHA2j'的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端。
可以看出,采用本发明实施例提供的技术方案,在进行动态文件传输时,通过先将动态文件进行分片得到小的分片文件,可以减少由于网络故障导致整个文件重新传输的概率,同时,通过将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端,可以加快文件的传输速度,因此采用本发明提供的技术方案缩短了动态文件的传输时间,另外通过在获取第二操作指令之后对分片文件重新计算哈希值,在第一哈希值与第二哈希值不相同的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端,可以在动态文件发生改变时,确保接收端接收的数据与发送端发送的数据一致。
请参阅图4,图4是本发明的另一实施例提供的一种动态文件的传输方法的流程示意图,如图4所示,本发明的另一实施例提供的一种动态文件的传输方法可以包括以下内容:
401、发送端获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端。
其中,发送端用于获取动态文件和将获取的动态文件通过网络传输到接收端。发送端可以为智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具备拍摄视频或获取视频或录音等功能且能够访问网络的电子设备。
其中,动态文件可以是发送端实时获取的视频文件或者实时获取的音频文件。
其中,接收端可以为服务器、智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具有通过网络接收数据、并能够反馈数据接收状态的电子设备,本发明实施例不作限定。
402、发送端根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容。
举例来说,若第一操作指令为录像指令、第一操作指令还用于指示将录像文件发送到接收端,则动态文件I为视频文件,发送端在获取第一操作指令后,创建视频文件,并且实时更新录像文件,直至获取到用于指示动态文件I创建完成的第二操作指令,才结束对动态文件I的更新。
403、发送端对所述动态文件I进行实时分片,依次获取多个分片文件。
404、发送端使用散列函数对分片文件Ij进行计算,得到与所述分片文件Ij对应的第一哈希值SHA2j,所述分片文件Ij为对所述动态文件I进行实时分片后获取的第j个分片文件,所述j为大于或者等于1的整数。
405、发送端生成与所述分片文件Ij对应的分片文件信息记录Lj,所述分片文件信息记录Lj保存在分片文件信息配置表P中,所述分片文件信息记录Lj中记录了所述分片文件Ij的位置信息和所述第一哈希值SHA2j。
406、发送端生成分片文件信息队列,所述分片文件信息队列记录了每个分片文件的文件传输状态,在所述分片文件信息队列中记录的所述分片文件Ij的文件传输状态为传输失败的情况下,将使用喷泉码对所述分片文件Ij进行编码后得到的文件重新传输到接收端。
407、发送端使用喷泉码对已获取的所述分片文件进行编码。
408、发送端将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
409、发送端获取第二操作指令,所述第二操作指令用于指示所述动态文件I创建完成。
410、发送端使用散列函数对所述分片文件Ij重新进行计算,得到与所述分片文件Ij对应的第二哈希值SHA2j'。
411、发送端比较所述第一哈希值SHA2j和所述第二哈希值SHA2j'是否相同。
412、发送端在所述第一哈希值SHA2j不同于所述第二哈希值SHA2j'的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端。
413、在获取所述第二操作指令之后,以及对所述动态文件I进行实时分片结束之后,向所述接收端发送所述分片文件信息配置表P,以使所述接收端根据所述分片文件信息配置表P将接收到的文件进行合并。
可以看出,采用本发明实施例提供的技术方案,在进行动态文件传输时,通过先将动态文件进行分片得到小的分片文件,可以减少由于网络故障导致整个文件重新传输的概率。同时,通过将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端,可以加快文件的传输速度,因此,采用本发明提供的技术方案缩短了动态文件的传输时间。另外,通过向接收端发送分片文件信息配置表P,便于接收端根据分片文件信息配置表P将接收到的文件进行合并,确保接收端接收的数据与发送端生成数据的一致性。
下面以一个具体的实施例进行描述,假设动态文件大小为30M,动态文件分片策略为每更新10M内容得到一个分片文件,发送端为手机,接收端为云服务器。具体地,如图5所示,本实施例提供的动态文件的传输方法可以包括:
501、手机获取用户输入的第一操作指令,其中,第一操作指令用于指示视频拍摄装置拍摄视频(比如,使用手机的摄像头拍摄视频)、以及指示将所述视频拍摄装置拍摄得到的视频文件上传到云服务器。
502、手机根据所述第一操作指令触发视频拍摄装置进行拍摄,创建视频文件I,随着拍摄时间的推移,拍摄的视频内容实时更新,视频文件I得到实时更新。
503、手机对视频文件I进行实时分片,当视频文件I增加至10M时,则获取第一个分片文件I1,当视频文件I增加至20M时,将10M至20M之间的文件片段作为第二个分片文件I2,当视频文件I增加至30M时,将20M至30M之间的文件片段作为第三个分片文件I3。
504、手机在获取第一个分片文件I1后,使用散列函数对分片文件I1进行计算,得到与所述分片文件I1对应的第一哈希值SHA21。生成与分片文件I1对应的分片文件信息记录L1,分片文件信息记录L1保存在分片文件信息配置表P中,分片文件信息记录L1中记录了分片文件I1的位置信息和第一哈希值SHA21。
类似的,在获取第二个分片文件I2后,使用散列函数对分片文件I2进行计算,得到与所述分片文件I2对应的第一哈希值SHA22。生成与分片文件I2对应的分片文件信息记录L2,分片文件信息记录L2保存在分片文件信息配置表P中,分片文件信息记录L2中记录了分片文件I3的位置信息和第一哈希值SHA22。
类似的,在获取第三个分片文件I3后,使用散列函数对分片文件I3进行计算,得到与所述分片文件I3对应的第一哈希值SHA23。生成与分片文件I3对应的分片文件信息记录L3,分片文件信息记录L2保存在分片文件信息配置表P中,分片文件信息记录L2中记录了分片文件I3的位置信息和第一哈希值SHA22。
505、手机在获取第一个分片文件I1后,手机使用Raptor编码对第一个分片文件I1使用Raptor喷泉码进行编码。
类似的,手机在获取第二个分片文件I2后,手机使用Raptor编码对第二个分片文件I2使用Raptor喷泉码进行编码。
类似的,手机在获取第三个分片文件I3后,手机使用Raptor编码对第三个分片文件I2使用Raptor喷泉码进行编码。
506、手机在对第一个分片文件I1使用Raptor喷泉码进行编码后,将使用Raptor喷泉码进行编码后得到的文件传输到云服务器。
类似的,手机在对第二个分片文件I2使用Raptor喷泉码进行编码后,将使用Raptor喷泉码进行编码后得到的文件传输到云服务器。
类似的,手机在对第三个分片文件I3使用Raptor喷泉码进行编码后,将使用Raptor喷泉码进行编码后得到的文件传输到云服务器。
507、手机获取第二操作指令,第二操作指令用于指示动态文件I创建完成。
508、手机使用散列函数对第一分片文件I1、第二分片文件I2、和第三分片文件I3重新进行计算,得到与第一分片文件I1对应的第二哈希值SHA21'、与第二分片文件I2对应的第二哈希值SHA22'、以及与第三分片文件I1对应的第二哈希值SHA23'。
509、手机比较所述第一哈希值SHA2j和所述第二哈希值SHA2j'是否相同,其中j=1、2或者3。
510、手机在第一哈希值SHA2j不同于第二哈希值SHA2j'的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将使用喷泉码对分片文件Ij重新进行编码后得到的文件传输到云服务器。
511、手机在获取第二操作指令之后,以及对动态文件I进行实时分片结束之后,向云服务器发送分片文件信息配置表P,以使云服务器根据分片文件信息配置表P将接收到的文件进行合并。
可以看出,采用本发明实施例提供的技术方案,在进行动态文件传输时,通过先将动态文件进行分片得到小的分片文件,可以减少由于网络故障导致整个文件重新传输的概率。同时,通过将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端,可以加快文件的传输速度,因此,采用本发明提供的技术方案缩短了动态文件的传输时间。另外,通过向接收端发送分片文件信息配置表P,便于接收端根据分片文件信息配置表P将接收到的文件进行合并,确保接收端接收的数据与发送端生成数据的一致性。
请参阅图6,图6为本发明的一个实施例提供的一种动态文件的传输装置的结构示意图。如图6所示,本发明实施例提供的一种动态文件的传输装置600可以包括:
第一获取单元601,用于获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端。
其中,动态文件的传输装置600作为发送端用于获取动态文件和将获取的动态文件通过网络传输到接收端。可以为智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具备拍摄视频或获取视频或录音等功能且能够访问网络的电子设备。
其中,动态文件可以是发送端实时获取的视频文件或者实时获取的音频文件。
其中,接收端可以为云服务器、智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具有通过网络接收数据、并能够反馈数据接收状态的电子设备,本发明实施例不作限定。
创建单元602,用于根据所述第一获取单元601获取的所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容。
举例来说,若第一操作指令为录像指令、并指示将录像文件发送到接收端,则动态文件I为视频文件,则发送端在获取第一操作指令后,创建视频文件,并且实时更新录像文件,直至获取到用于指示动态文件I创建完成的第二操作指令,才结束对动态文件I的更新。
分片单元603,用于对所述创建单元602创建的所述动态文件I进行实时分片,依次获取多个分片文件。
可选的,在本发明一些可能的实施方式中,可以根据文件分片策略将已获取的动态文件进行分片,比如可以按照预设的大小进行分片,举例来说,可以按照10M的大小将动态文件进行分片,即将开始获取动态文件到动态文件更新到10M时的文件片段作为第一分片文件,当动态文件更新到20M时,可以将10M至20M之间的文件片段作为第二个分片文件。当然也可以按照预设的时间间隔对动态文件进行分片,举例来说,若动态文件为实时增加的视频文件时,则可以设置每隔两秒钟对动态文件进行分片,即将0秒至2秒之间的视频片段作为第一分片文件,将2秒至4秒之间的视频片段作为第二分片文件。在发送端将动态文件进行分片后,对分片文件使用喷泉码进行编码,然后将编码后的文件传输到接收端。
编码单元604,用于使用喷泉码对所述分片单元对所述动态文件进行实时分片获取的所述分片文件进行编码。
可选的,在本发明一些可能的实施方式中,可以使用Raptor编码对已获取的所述分片文件进行编码。
第一传输单元605,用于将所述编码单元604使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
可以看出,采用本发明实施例提供的技术方案,在进行动态文件传输时,通过先将动态文件进行分片得到小的分片文件,可以减少由于网络故障导致整个文件重新传输的概率,另外,通过将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端,可以加快文件的传输速度,因此采用本发明提供的技术方案缩短了动态文件的传输时间。
请参阅图7,图7为本发明的另一实施例提供的一种动态文件的传输装置的结构示意图。如图7所示,本发明实施例提供的一种动态文件的传输装置700可以包括:
第一获取单元701,用于获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端。
其中,动态文件的传输装置700作为发送端用于获取动态文件和将获取的动态文件通过网络传输到接收端。可以为智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具备拍摄视频或获取视频或录音等功能且能够访问网络的电子设备。
其中,动态文件可以是发送端实时获取的视频文件或者实时获取的音频文件。
其中,接收端可以为云服务器、智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具有通过网络接收数据、并能够反馈数据接收状态的电子设备,本发明实施例不作限定。
创建单元702,用于根据所述第一获取单元701获取的所述第一操作指令创建动态文件I,并实时更新所述动态文件I的内容。
举例来说,若第一操作指令为录像指令、并指示将录像文件发送到接收端,则动态文件I为视频文件,则发送端在获取第一操作指令后,创建视频文件,并且实时更新录像文件,直至获取到用于指示动态文件I创建完成的第二操作指令,才结束对动态文件I的更新。
分片单元703,用于对所述创建单元702创建的所述动态文件I进行实时分片,依次获取多个分片文件。
可选的,在本发明一些可能的实施方式中,可以根据文件分片策略将已获取的动态文件进行分片,比如可以按照预设的大小进行分片,举例来说,可以按照10M的大小将动态文件进行分片,即将开始获取动态文件到动态文件更新到10M时的文件片段作为第一分片文件,当动态文件更新到20M时,可以将10M至20M之间的文件片段作为第二个分片文件。当然也可以按照预设的时间间隔对动态文件进行分片,举例来说,若动态文件为实时增加的视频文件时,则可以设置每隔两秒钟对动态文件进行分片,即将0秒至2秒之间的视频片段作为第一分片文件,将2秒至4秒之间的视频片段作为第二分片文件。在发送端将动态文件进行分片后,对分片文件使用喷泉码进行编码,然后将编码后的文件传输到接收端。
编码单元704,用于使用喷泉码对所述分片单元对所述动态文件进行实时分片获取的所述分片文件进行编码。
可选的,在本发明一些可能的实施方式中,可以使用Raptor编码对已获取的所述分片文件进行编码。
第一传输单元705,用于将所述编码单元704使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
第一计算单元706,用于在所述分片单元703对所述动态文件I进行实时分片之后,使用散列函数对分片文件Ij进行计算,得到与所述分片文件Ij对应的第一哈希值SHA2j,其中,所述分片文件Ij为对所述动态文件I进行实时分片后获取的第j个分片文件,所述j为大于或者等于1的整数。
第一生成单元707,用于生成与所述分片文件Ij对应的分片文件信息记录Lj,所述分片文件信息记录Lj保存在分片文件信息配置表P中,所述分片文件信息记录Lj中记录了所述分片文件Ij的位置信息和所述第一哈希值SHA2j。
第二获取单元708,用于在所述创建单元702根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容之后,获取第二操作指令,所述第二操作指令用于指示所述动态文件I创建完成。
第二计算单元709,用于在所述第二获取单元获取所述第二操作指令之后,使用散列函数对所述分片文件Ij重新进行计算,得到与所述分片文件Ij对应的第二哈希值SHA2j'。
比较单元710,用于比较所述第一哈希值SHA2j和所述第二哈希值SHA2j'是否相同。
第一处理单元711,用于在所述比较单元710的比较结果为所述第一哈希值SHA2j不同于所述第二哈希值SHA2j'的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端。
可以看出,采用本发明实施例提供的技术方案,在进行动态文件传输时,通过先将动态文件进行分片得到小的分片文件,可以减少由于网络故障导致整个文件重新传输的概率,同时,通过将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端,可以加快文件的传输速度,因此采用本发明提供的技术方案缩短了动态文件的传输时间,另外通过在获取第二操作指令之后对分片文件重新计算哈希值,在第一哈希值与第二哈希值不相同的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端,可以在动态文件发生改变时,确保接收端接收的数据与发送端生成数据的一致性。
请参阅图8,图8为本发明的另一实施例提供的一种动态文件的传输装置的结构示意图。如图8所示,本发明实施例提供的一种动态文件的传输装置800可以包括:
第一获取单元801,用于获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端。
其中,动态文件的传输装置800作为发送端用于获取动态文件和将获取的动态文件通过网络传输到接收端。可以为智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具备拍摄视频或获取视频或录音等功能且能够访问网络的电子设备。
其中,动态文件可以是发送端实时获取的视频文件或者实时获取的音频文件。
其中,接收端可以为云服务器、智能手机、笔记本电脑、PDA、PAD、PMP、导航装置等具有通过网络接收数据、并能够反馈数据接收状态的电子设备,本发明实施例不作限定。
创建单元802,用于根据所述第一获取单元801获取的所述第一操作指令创建动态文件I,并实时更新所述动态文件I的内容。
举例来说,若第一操作指令为录像指令、并指示将录像文件发送到接收端,则动态文件I为视频文件,则发送端在获取第一操作指令后,创建视频文件,并且实时更新录像文件,直至获取到用于指示动态文件I创建完成的第二操作指令,才结束对动态文件I的更新。
分片单元803,用于对所述创建单元802创建的所述动态文件I进行实时分片,依次获取多个分片文件。
可选的,在本发明一些可能的实施方式中,可以根据文件分片策略将已获取的动态文件进行分片,比如可以按照预设的大小进行分片,举例来说,可以按照10M的大小将动态文件进行分片,即将开始获取动态文件到动态文件更新到10M时的文件片段作为第一分片文件,当动态文件更新到20M时,可以将10M至20M之间的文件片段作为第二个分片文件。当然也可以按照预设的时间间隔对动态文件进行分片,举例来说,若动态文件为实时增加的视频文件时,则可以设置每隔两秒钟对动态文件进行分片,即将0秒至2秒之间的视频片段作为第一分片文件,将2秒至4秒之间的视频片段作为第二分片文件。在发送端将动态文件进行分片后,对分片文件使用喷泉码进行编码,然后将编码后的文件传输到接收端。
编码单元804,用于使用喷泉码对所述分片单元803对所述动态文件进行实时分片获取的所述分片文件进行编码。
可选的,在本发明一些可能的实施方式中,可以使用Raptor编码对已获取的所述分片文件进行编码。
第一传输单元805,用于将所述编码单元804使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
第一计算单元806,用于在所述分片单元803对所述动态文件I进行实时分片之后,使用散列函数对分片文件Ij进行计算,得到与所述分片文件Ij对应的第一哈希值SHA2j,其中,所述分片文件Ij为对所述动态文件I进行实时分片后获取的第j个分片文件,所述j为大于或者等于1的整数。
第一生成单元807,用于生成与所述分片文件Ij对应的分片文件信息记录Lj,所述分片文件信息记录Lj保存在分片文件信息配置表P中,所述分片文件信息记录Lj中记录了所述分片文件Ij的位置信息和所述第一哈希值SHA2j。
第二获取单元808,用于在所述创建单元802根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容之后,获取第二操作指令,所述第二操作指令用于指示所述动态文件I创建完成。
第二计算单元809,用于在所述第二获取单元获取所述第二操作指令之后,使用散列函数对所述分片文件Ij重新进行计算,得到与所述分片文件Ij对应的第二哈希值SHA2j'。
比较单元810,用于比较所述第一哈希值SHA2j和所述第二哈希值SHA2j'是否相同。
第一处理单元811,用于在所述比较单元810的比较结果为所述第一哈希值SHA2j不同于所述第二哈希值SHA2j'的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端。
第二传输单元812,用于在所述第二获取单元获取所述第二操作指令之后,以及所述分片单元对所述动态文件I进行实时分片结束之后,向所述接收端发送所述分片文件信息配置表P,以使所述接收端根据所述分片文件信息配置表P将接收到的文件进行合并。
第二生成单元813,用于在所述分片单元对所述动态文件I进行实时分片之后,生成分片文件信息队列,所述分片文件信息队列记录了每个分片文件的文件传输状态,
第三传输单元814,用于在所述分片文件信息队列中记录的所述分片文件Ij的文件传输状态为传输失败的情况下,将使用喷泉码对所述分片文件Ij进行编码后得到的文件重新传输到接收端。
可以看出,采用本发明实施例提供的技术方案,在进行动态文件传输时,通过先将动态文件进行分片得到小的分片文件,可以减少由于网络故障导致整个文件重新传输的概率。同时,通过将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端,可以加快文件的传输速度,因此,采用本发明提供的技术方案缩短了动态文件的传输时间。另外,通过向接收端发送分片文件信息配置表P,便于接收端根据分片文件信息配置表P将接收到的文件进行合并,确保接收端接收的数据与发送端发送的数据的一致性。
参见图9,图9为本发明实施例提供的一种电子设备的结构示意图,所述电子设备900,可以包括:
处理器901、存储器902、通信接口903和总线904;
其中,所述处理器901、所述存储器902和所述通信接口903通过所述总线904连接并完成相互间的通信;
所述存储器902存储可执行程序代码;
所述处理器901通过读取所述存储器902中存储的可执行程序代码来运行与所述可执行程序代码对应的程序,以用于执行一种动态文件的传输方法;其中,一种动态文件的传输方法包括:
获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端;
根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容;
对所述动态文件I进行实时分片,依次获取多个分片文件;
使用喷泉码对已获取的所述分片文件进行编码;
将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
可以看出,采用本发明实施例提供的技术方案,在进行动态文件传输时,通过先将动态文件进行分片得到小的分片文件,可以减少由于网络故障导致整个文件重新传输的概率,另外,通过将使用喷泉码对已获取的分片文件进行编码后得到的文件传输到接收端,可以加快文件的传输速度,因此采用本发明提供的技术方案缩短了动态文件的传输时间。
本发明实施例还提供了一种存储介质,其中,该存储介质用于存储应用程序,所述应用程序用于在运行时执行本发明实施例所述的一种视频文件的备份方法。
本发明实施例还提供了一种应用程序,其中,该应用程序用于在运行时执行本发明实施例所述的一种动态文件的传输方法。
需要说明的是,对于前述的各方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明并不受所描述的动作顺序的限制,因为依据本发明,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作和模块并不一定是本发明所必须的。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述的部分,可以参见其他实施例的相关描述。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置,可通过其它的方式实现。例如,以上所描述的装置实施例是示意性的,例如所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个***,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可为个人计算机、服务器或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、只读存储器(ROM,Read-OnlyMemory)、随机存取存储器(RAM,RandomAccessMemory)、移动硬盘、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述,以上实施例仅用以说明本发明技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,其中,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的范围。
Claims (10)
1.一种动态文件的传输方法,其特征在于,包括:
获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端;
根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容;
对所述动态文件I进行实时分片,依次获取多个分片文件;
使用喷泉码对已获取的所述分片文件进行编码;
将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
2.根据权利要求1所述的方法,其特征在于,在对所述动态文件I进行实时分片之后,所述方法还包括:
使用散列函数对分片文件Ij进行计算,得到与所述分片文件Ij对应的第一哈希值SHA2j,所述分片文件Ij为对所述动态文件I进行实时分片后获取的第j个分片文件,所述j为大于或者等于1的整数;
生成与所述分片文件Ij对应的分片文件信息记录Lj,所述分片文件信息记录Lj保存在分片文件信息配置表P中,所述分片文件信息记录Lj中记录了所述分片文件Ij的位置信息和所述第一哈希值SHA2j。
3.根据权利要求2所述的方法,其特征在于,在所述根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容之后,所述方法还包括:
获取第二操作指令,所述第二操作指令用于指示所述动态文件I创建完成;
在获取所述第二操作指令之后,所述方法还包括:
使用散列函数对所述分片文件Ij重新进行计算,得到与所述分片文件Ij对应的第二哈希值SHA2j';
比较所述第一哈希值SHA2j和所述第二哈希值SHA2j'是否相同;
在所述第一哈希值SHA2j不同于所述第二哈希值SHA2j'的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端。
4.根据权利要求3所述的方法,其特征在于,在获取所述第二操作指令之后,以及对所述动态文件I进行实时分片结束之后,所述方法还包括:
向所述接收端发送所述分片文件信息配置表P,以使所述接收端根据所述分片文件信息配置表P将接收到的文件进行合并。
5.根据权利要求2所述的方法,其特征在于,在对所述动态文件I进行实时分片之后,所述方法还包括:
生成分片文件信息队列,所述分片文件信息队列记录了每个分片文件的文件传输状态,在所述分片文件信息队列中记录的所述分片文件Ij的文件传输状态为传输失败的情况下,将使用喷泉码对所述分片文件Ij进行编码后得到的文件重新传输到接收端。
6.根据权利要求1至5任一项所述的方法,其特征在于,所述使用喷泉码对已获取的所述分片文件进行编码,包括:
使用Raptor编码对已获取的所述分片文件进行编码。
7.一种动态文件的传输装置,其特征在于,包括:
第一获取单元,用于获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端;
创建单元,用于根据所述第一获取单元获取的所述第一操作指令创建动态文件I,并实时更新所述动态文件I的内容;
分片单元,用于对所述创建单元创建的所述动态文件I进行实时分片,依次获取多个分片文件;
编码单元,用于使用喷泉码对所述分片单元对所述动态文件进行实时分片获取的所述分片文件进行编码;
第一传输单元,用于将所述编码单元使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
8.根据权利要求7所述的传输装置,其特征在于,所述传输装置还包括:
第一计算单元,用于在所述分片单元对所述动态文件I进行实时分片之后,使用散列函数对分片文件Ij进行计算,得到与所述分片文件Ij对应的第一哈希值SHA2j,其中,所述分片文件Ij为对所述动态文件I进行实时分片后获取的第j个分片文件,所述j为大于或者等于1的整数;
第一生成单元,用于生成与所述分片文件Ij对应的分片文件信息记录Lj,所述分片文件信息记录Lj保存在分片文件信息配置表P中,所述分片文件信息记录Lj中记录了所述分片文件Ij的位置信息和所述第一哈希值SHA2j。
9.根据权利要求8所述的传输装置,其特征在于,所述传输装置还包括:
第二获取单元,用于在所述创建单元根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容之后,获取第二操作指令,所述第二操作指令用于指示所述动态文件I创建完成;
第二计算单元,用于在所述第二获取单元获取所述第二操作指令之后,使用散列函数对所述分片文件Ij重新进行计算,得到与所述分片文件Ij对应的第二哈希值SHA2j';
比较单元,用于比较所述第一哈希值SHA2j和所述第二哈希值SHA2j'是否相同;
第一处理单元,用于在所述比较单元的比较结果为所述第一哈希值SHA2j不同于所述第二哈希值SHA2j'的情况下,使用喷泉码对所述分片文件Ij重新进行编码,并将所述使用喷泉码对所述分片文件Ij重新进行编码后得到的文件传输到接收端。
10.一种电子设备,其特征在于,包括:处理器、存储器、通信接口和总线;
所述处理器、所述存储器和所述通信接口通过所述总线连接并完成相互间的通信;
所述存储器存储可执行程序代码;
所述处理器通过读取所述存储器中存储的可执行程序代码来运行与所述可执行程序代码对应的程序,以用于执行一种动态文件的传输方法;其中,所述动态文件的传输方法包括:
获取第一操作指令,所述第一操作指令用于指示创建动态文件I、以及指示将已创建的所述动态文件I传输给接收端;
根据所述第一操作指令创建所述动态文件I,并实时更新所述动态文件I的内容;
对所述动态文件I进行实时分片,依次获取多个分片文件;
使用喷泉码对已获取的所述分片文件进行编码;
将所述使用喷泉码对已获取的所述分片文件进行编码后得到的文件传输到接收端。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610147622.6A CN105827700A (zh) | 2016-03-15 | 2016-03-15 | 一种动态文件的传输方法、装置及电子设备 |
PCT/CN2016/109711 WO2017157062A1 (zh) | 2016-03-15 | 2016-12-13 | 一种动态文件的传输方法、装置及电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610147622.6A CN105827700A (zh) | 2016-03-15 | 2016-03-15 | 一种动态文件的传输方法、装置及电子设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN105827700A true CN105827700A (zh) | 2016-08-03 |
Family
ID=56987763
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610147622.6A Pending CN105827700A (zh) | 2016-03-15 | 2016-03-15 | 一种动态文件的传输方法、装置及电子设备 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN105827700A (zh) |
WO (1) | WO2017157062A1 (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2017157062A1 (zh) * | 2016-03-15 | 2017-09-21 | 北京金山安全软件有限公司 | 一种动态文件的传输方法、装置及电子设备 |
WO2023130801A1 (zh) * | 2022-01-10 | 2023-07-13 | 深圳智慧林网络科技有限公司 | 基于函数的数据发送方法、装置、设备和数据接收方法 |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110401725A (zh) * | 2019-08-23 | 2019-11-01 | 深圳市鹰硕技术有限公司 | 文件上传方法、装置、终端、服务器、***及存储介质 |
WO2021056594A1 (zh) * | 2019-09-29 | 2021-04-01 | 西门子股份公司 | 编排前端应用程序的方法、装置、电子设备、介质和程序产品 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102055785A (zh) * | 2009-11-09 | 2011-05-11 | 杭州华三通信技术有限公司 | 分布式***的在线升级方法、分布式***及设备 |
CN103493495A (zh) * | 2011-04-27 | 2014-01-01 | 莫雷加***股份有限公司 | 具有虚拟文件***的自适应视频服务器及其使用方法 |
CN103729225A (zh) * | 2014-01-22 | 2014-04-16 | 中国人民解放军国防科学技术大学 | 一种基于内容分块的远程文件实时更新方法 |
CN103780921A (zh) * | 2014-01-17 | 2014-05-07 | 上海聚力传媒技术有限公司 | 一种播放直播视频信息的方法和设备 |
CN104104727A (zh) * | 2014-07-24 | 2014-10-15 | 中国传媒大学 | 一种基于Raptor码的大文件传输方法 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2011100901A2 (zh) * | 2011-04-07 | 2011-08-25 | 华为技术有限公司 | 媒体内容的传输处理方法、装置与*** |
CN103974147A (zh) * | 2014-03-07 | 2014-08-06 | 北京邮电大学 | 一种基于mpeg-dash协议的带***率切换控制和静态摘要技术的在线视频播控*** |
CN104952096B (zh) * | 2014-03-31 | 2018-06-08 | 中国电信股份有限公司 | Cpu和gpu混合云渲染方法、装置和*** |
CN105827700A (zh) * | 2016-03-15 | 2016-08-03 | 北京金山安全软件有限公司 | 一种动态文件的传输方法、装置及电子设备 |
-
2016
- 2016-03-15 CN CN201610147622.6A patent/CN105827700A/zh active Pending
- 2016-12-13 WO PCT/CN2016/109711 patent/WO2017157062A1/zh active Application Filing
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102055785A (zh) * | 2009-11-09 | 2011-05-11 | 杭州华三通信技术有限公司 | 分布式***的在线升级方法、分布式***及设备 |
CN103493495A (zh) * | 2011-04-27 | 2014-01-01 | 莫雷加***股份有限公司 | 具有虚拟文件***的自适应视频服务器及其使用方法 |
CN103780921A (zh) * | 2014-01-17 | 2014-05-07 | 上海聚力传媒技术有限公司 | 一种播放直播视频信息的方法和设备 |
CN103729225A (zh) * | 2014-01-22 | 2014-04-16 | 中国人民解放军国防科学技术大学 | 一种基于内容分块的远程文件实时更新方法 |
CN104104727A (zh) * | 2014-07-24 | 2014-10-15 | 中国传媒大学 | 一种基于Raptor码的大文件传输方法 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2017157062A1 (zh) * | 2016-03-15 | 2017-09-21 | 北京金山安全软件有限公司 | 一种动态文件的传输方法、装置及电子设备 |
WO2023130801A1 (zh) * | 2022-01-10 | 2023-07-13 | 深圳智慧林网络科技有限公司 | 基于函数的数据发送方法、装置、设备和数据接收方法 |
Also Published As
Publication number | Publication date |
---|---|
WO2017157062A1 (zh) | 2017-09-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN105827700A (zh) | 一种动态文件的传输方法、装置及电子设备 | |
CN109359223A (zh) | 基于纠删码实现的区块链账本分布式存储技术 | |
CN101783955B (zh) | 一种数据异常时的恢复方法和设备 | |
CN103428227A (zh) | 基于Huffman编码的IP隐秘通信方法 | |
CN103150427A (zh) | 一种基于ssd硬盘缓存加速与备份的raid设计方法 | |
CN103534968A (zh) | 一种以太网物理层的编码、解码方法和装置 | |
CN110018783A (zh) | 一种数据存储方法、装置及*** | |
US9264181B2 (en) | Communication system, method and receiver applicable thereto | |
CN115395961A (zh) | 基于联合中间件的数据无损压缩及加密传输方法 | |
CN106453663B (zh) | 改进的基于云服务的存储扩容方法及装置 | |
CN108259138A (zh) | 一种利用喷泉码多次反馈的安全传输方法 | |
CN101179798B (zh) | 在手机之间传输数据的操作方法及装置 | |
CN107222294A (zh) | 一种改进的喷泉码度分布算法 | |
CN116842205A (zh) | 一种游戏回放方法、装置及存储介质 | |
CN113518113B (zh) | 一种基于区块链和里德-所罗门码的文件存储方法、计算机设备及存储介质 | |
CN116094652A (zh) | 音视频数据的传输方法、装置、电子设备及可读介质 | |
CN103379364A (zh) | 视频文件的处理方法、装置、视频服务器和*** | |
US9686221B2 (en) | Error correction for interactive message exchanges using summaries | |
CN104081747A (zh) | 传输http报文的方法、编码装置和解码装置 | |
CN103929447B (zh) | 一种基于PEEK操作的解析HTTP chunked编码数据的方法 | |
CN103117955A (zh) | 消息传输方法及装置、*** | |
CN110636368B (zh) | 媒体播放方法、***、装置及存储介质 | |
CN103532666B (zh) | 提高分布式传输中数据传输效率和lt码性能的方法 | |
CN109005011A (zh) | 一种用于水声网络的数据传输方法、***及可读存储介质 | |
CN105491544A (zh) | 一种短消息压缩通信方法和*** |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20160803 |
|
RJ01 | Rejection of invention patent application after publication |