文件服务器、终端及其文件分包传输方法

文档序号:9730271阅读:488来源:国知局
文件服务器、终端及其文件分包传输方法
【技术领域】
[0001]本发明涉及通信技术领域,具体而言,本发明涉及一种文件服务器、终端及其文件分包传输方法。
【背景技术】
[0002]随着科技的进步和社会的发展,互联网和移动互联网等网络已经得到广泛的普及。用户通常通过电脑、智能手机和平板电脑等终端接入网络,获取资讯、网络购物和信息交互等等。
[0003]终端在信息交互(例如即时通讯)的过程中,通常需要将图片文件、视频文件等文件向服务器上传,再由服务器进行后续传输。
[0004]现有的一种文件传输方法包括:发送端将待传输的文件划分成多个分片文件;依照分片顺序逐个将各分片文件向接收端传输;监控每个分片文件是否传输成功,若传输成功则继续对下一个分片文件进行传输,若传输失败则对该分片文件进行重新传输。
[0005]然而,本发明的发明人发现,上述文件传输的过程耗费的时间较长,文件传输速度较慢,传输效率低下;并且该文件传输的过程占用网络带宽时间较长,影响了相关网络的传输效率。
[0006]目前,另一种文件传输方法包括:发送端将待传输的文件划分成多个分片文件,与接收端建立多个线程,将多个分片文件分别通过多个线程并行发送给接收端。
[0007]然而,本发明的发明人发现,上述并行发送分片文件的过程中,需要占用大量的网络带宽和缓存空间等系统资源,降低了相关网络中其它传输任务的传输效率。
[0008]综上,现有的文件传输方法存在传输效率较低、或者占用带宽和系统资源较多的缺陷。
[0009]因此,有必要提供一种文件服务器、终端及其文件分包传输方法,以占用较小的网络带宽和系统资源的情况下,提升文件传输效率。

【发明内容】

[0010]本发明针对现有的文件传输方式的缺点,提出一种文件服务器、终端及其文件分包传输方法,用以解决现有技术存在传输速度较慢、或者占用带宽和系统资源较多的问题。[0011 ]本发明的实施例根据一个方面,提供了一种文件分包传输方法,包括:
[0012]源终端根据文件划分策略确定出文件的待划分片段的数目后,将所述文件的文件名、数目信息上传至文件服务器;
[0013]所述源终端根据所述文件划分策略对所述文件进行划分,对划分出的片段依次分配片段序号;并
[0014]对于每个片段,将该片段及其片段序号封装在一个分包文件中上传至文件服务器;之后,向所述文件服务器发送文件接收状况查询请求;
[0015]所述源终端在接收到所述文件服务器返回的重发信息后,根据所述重发信息中的片段序号,重新发送相应的分包文件;
[0016]其中,所述重发信息是所述文件服务器接收到所述文件接收状况查询请求后,根据其中携带的文件名,以及之前接收的所述文件的各分包文件中携带的片段序号,以及所述数目信息确定的。
[0017]本发明的实施例根据另一个方面,还提供了一种文件分包传输方法,包括:
[0018]文件服务器接收源终端上传的文件的文件名、和文件片段的数目信息并对应存储;
[0019]所述文件服务器接收所述源终端上传的分包文件后,将所述分包文件与所述文件名对应存储;
[0020]所述文件服务器接收到所述源终端发送的文件接收状况查询请求后,根据其中携带的文件名,以及之前接收的所述文件的各分包文件中携带的片段序号,以及所述数目信息,确定出未接收到的分包文件的片段序号;将确定出的片段序号携带于重发信息中向所述源终端返回。
[0021]本发明的实施例根据另一个方面,还提供了一种终端,包括:
[0022]文件信息上传模块,用于根据文件划分策略确定出文件的待划分片段的数目后,将所述文件的文件名、数目信息上传至文件服务器;
[0023]分包文件上传模块,用于根据所述文件划分策略对所述文件进行划分,对划分出的片段依次分配片段序号;并对于每个片段,将该片段及其片段序号封装在一个分包文件中上传至文件服务器;之后,发送上传结束通知;
[0024]分包文件重传模块,用于接收到上传结束通知后,向所述文件服务器发送文件接收状况查询请求;以及在接收到返回的重发信息后,根据所述重发信息中的片段序号,重新发送相应的分包文件;
[0025]其中,所述重发信息是所述文件服务器接收到所述文件接收状况查询请求后,根据其中携带的文件名,以及之前接收的所述文件的各分包文件中携带的片段序号,以及所述数目信息确定的。
[0026]本发明的实施例根据另一个方面,还提供了一种文件服务器,包括:
[0027]文件信息存储模块,用于接收源终端上传的文件的文件名、和文件片段的数目信息并对应存储;
[0028]分包文件接收模块,用于接收所述源终端上传的分包文件后,将所述分包文件与所述文件名对应存储;
[0029]信息反馈模块,用于接收到所述源终端发送的文件接收状况查询请求后,根据其中携带的文件名,以及之前所述分包文件接收模块接收的所述文件的各分包文件中携带的片段序号,以及所述文件信息存储模块接收的数目信息,确定出未接收到的分包文件的片段序号;将确定出的片段序号携带于重发信息中向所述源终端返回。
[0030]本发明的实施例中,源终端将文件待划分的片段的数目信息、以及该文件的所有分包文件都上传后,由文件服务器根据接收的数目信息和各分包文件中的片段序号,一次性确定出重发信息并返回;源终端可以根据重发信息重发分包文件。与现有方法中每传输一个分片文件即检查是否传输成功以生成重发信息相比,文件服务器确定重发信息的次数从多次缩减为一次,可以节省传输整个文件所花费的时间,从而提升文件传输的速度和效率。
[0031]而且,本发明实施例中,源终端封装的分包文件可以通过运行在单个线程中的会话上传至文件服务器,与现有技术中将多个分片文件分别通过多个线程进行并行上传相比,可以节省网络带宽,可以节省源终端和文件服务器中的缓存空间等资源。
[0032]因此,本发明实施例可在占用较小的网络带宽和系统资源的情况下,提升文件传输效率。
[0033]本发明附加的方面和优点将在下面的描述中部分给出,这些将从下面的描述中变得明显,或通过本发明的实践了解到。
【附图说明】
[0034]本发明上述的和/或附加的方面和优点从下面结合附图对实施例的描述中将变得明显和容易理解,其中:
[0035]图1为本发明实施例的文件分包传输系统的架构示意图;
[0036]图2a和图2b都为本发明实施例的文件分包传输方法的流程示意图;
[0037]图3为本发明实施例的终端的内部结构的框架示意图;
[0038]图4为本发明实施例的文件服务器的内部结构的框架示意图。
【具体实施方式】
[0039]下面详细描述本发明的实施例,所述实施例的示例在附图中示出,其中自始至终相同或类似的标号表示相同或类似的元件或具有相同或类似功能的元件。下面通过参考附图描述的实施例是示例性的,仅用于解释本发明,而不能解释为对本发明的限制。
[0040]本技术领域技术人员可以理解,除非特意声明,这里使用的单数形式“一”、“一个”、“所述”和“该”也可包括复数形式。应该进一步理解的是,本发明的说明书中使用的措辞“包括”是指存在所述特征、整数、步骤、操作、元件和/或组件,但是并不排除存在或添加一个或多个其他特征、整数、步骤、操作、元件、组件和/或它们的组。应该理解,当我们称元件被“连接”或“耦接”到另一元件时,它可以直接连接或耦接到其他元件,或者也可以存在中间元件。此外,这里使用的“连接”或“親接”可以包括无线连接或无线耦接。这里使用的措辞“和/或”包括一个或更多个相关联的列出项的全部或任一单元和全部组合。
[0041]本技术领域技术人员可以理解,除非另外定义,这里使用的所有术语(包括技术术语和科学术语),具有与本发明所属领域中的普通技术人员的一般理解相同的意义。还应该理解的是,诸如通用字典中定义的那些术语,应该被理解为具有与现有技术的上下文中的意义一致的意义,并且除非像这里一样被特定定义,否则不会用理想化或过于正式的含义来解释。
[0042]本技术领域技术人员可以理解,这里所使用的“终端”、“终端设备”既包括无线信号接收器
当前第1页1 2 3 4 5 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1