本发明实施例涉及存储技术领域,具体涉及一种文件存储方法及装置、文件提取方法及装置。
背景技术:
随着电子技术的不断发展,智能设备越来越普及,信息共享越来越频繁,数据的保密性和安全性要求也越来越高。
现有的文件存储技术中,隐私文件或者保密文件等重要数据都是保存在本机的磁盘或者云服务器,可能会被泄露或者窃取,对于需要安全性比较高的场景,现有技术无法保证数据安全。
因此,亟需提供一种数据存储技术,适用于安全性比较高的场景,防止数据被泄露或者窃取。
技术实现要素:
鉴于上述问题,本发明实施例提出了克服上述问题的一种文件存储方法及装置、文件提取方法及装置。
第一方面,本发明实施例提出一种文件存储方法,包括:
第一设备在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备;
所述第一设备对所述目标文件进行分割,生成多个数据包;
所述第一设备将与各第二设备对应的数据包发送给各自对应的第二设备进行存储;
其中,所述数据包携带有分割信息;所述分割信息包括:第一指示信息;所述第一指示信息是所述第一设备根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的。
第二方面,本发明实施例还提出一种文件提取方法,包括:
第三设备在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送第一提取请求;所述第一提取请求中携带有所述目标文件对应的所有第一指示信息;
所述第三设备接收各第四设备反馈的提取响应;所述第四设备为接收到所述第一提取请求且确定本地存储有任一个所述第一指示信息的设备;所述提取响应携带有校验信息;所述校验信息为所述第四设备基于本地存储的第一指示信息对应的数据包生成的校验信息;
所述第三设备对各校验信息进行校验,在各校验信息校验成功后,向各第四设备发送第二提取请求;所述第二提取请求中携带有各第四设备本地存储的第一指示信息;
所述第三设备接收各第四设备反馈的本地存储的第一指示信息对应的数据包;
所述第三设备基于接收到的各数据包,生成所述目标文件。
第三方面,本发明实施例还提出一种文件提取方法,包括:
第三设备在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送提取请求;所述提取请求中携带有所述目标文件对应的所有第一指示信息;
所述第三设备接收各第四设备反馈的数据包;所述第四设备为接收到所述提取请求且确定本地存储有任一个所述第一指示信息的设备;
所述第三设备对各数据包携带的分割信息进行校验,在各分割信息校验成功后,基于接收到的各数据包,生成所述目标文件;其中,所述分割信息包括第一指示信息。
第四方面,本发明实施例还提出一种文件存储装置,包括:
确定单元,用于在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备;
生成单元,用于对所述目标文件进行分割,生成多个数据包;
第一发送单元,用于将与各第二设备对应的数据包发送给各自对应的第二设备进行存储;
其中,所述数据包携带有分割信息;所述分割信息包括:第一指示信息;所述第一指示信息是所述第一设备根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的。
第五方面,本发明实施例还提出一种文件提取装置,包括:
第一发送单元,用于在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送第一提取请求;所述第一提取请求中携带有所述目标文件对应的所有第一指示信息;
第一接收单元,用于接收各第四设备反馈的提取响应;所述第四设备为接收到所述第一提取请求且确定本地存储有任一个所述第一指示信息的设备;所述提取响应携带有校验信息;所述校验信息为所述第四设备基于本地存储的第一指示信息对应的数据包生成的校验信息;
第一处理单元,用于对各校验信息进行校验,在各校验信息校验成功后,向各第四设备发送第二提取请求;所述第二提取请求中携带有各第四设备本地存储的第一指示信息;
第二接收单元,用于接收各第四设备反馈的本地存储的第一指示信息对应的数据包;
生成单元,用于基于所述第二接收单元接收到的各数据包,生成所述目标文件。
第六方面,本发明实施例还提出一种文件提取装置,包括:
第二发送单元,用于在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送提取请求;所述提取请求中携带有所述目标文件对应的所有第一指示信息;
第三接收单元,用于接收各第四设备反馈的数据包;所述第四设备为接收到所述提取请求且确定本地存储有任一个所述第一指示信息的设备;
第二处理单元,用于对各数据包携带的分割信息进行校验,在各分割信息校验成功后,基于接收到的各数据包,生成所述目标文件;其中,所述分割信息包括第一指示信息。
本发明实施例提出的文件存储方法及装置,通过将待存储的文件分割成多份,每份存储在不同的设备上并利用设备标识与文件标识进行唯一指示,实现文件存储,适用于安全性比较高的场景,防止数据被泄露或者窃取。
在本发明实施例提出的文件存储方法及装置的基础上,本发明实施例进一步提出文件提取方法及装置,对基于设备标识与文件标识生成的指示信息进行校验,确定存储有文件分片的各设备,从而基于文件分片对应的分割序号,将各文件分片合成为待提取的文件,实现文件提取,适用于安全性比较高的场景,防止数据被泄露或者窃取。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的一种文件存储方法流程图;
图2为本发明实施例提供的另一种文件存储方法流程图;
图3为本发明实施例提供的又一种文件存储方法流程图;
图4为本发明实施例提供的一种文件提取方法流程图;
图5为本发明实施例提供的另一种文件提取方法流程图;
图6为本发明实施例提供的一种文件存储装置框图;
图7为本发明实施例提供的一种文件提取装置框图;
图8为本发明实施例提供的另一种文件提取装置框图;
图9为本发明实施例提供的一种文件存储装置的结构示意图;
图10为本发明实施例提供的一种文件提取装置的结构示意图;
图11为本发明实施例提供的另一种文件提取装置结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
需要说明的是,在本文中,诸如“第一”和“第二”等之类的关系术语仅仅用来将相同的名称区分开来,而不是暗示这些名称之间的关系或者顺序。
文件存储方法第一实施例
本实施例公开一种文件存储方法,如图1所示,可包括以下步骤101~103:
101、第一设备在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备。
本实施例中,共享存储网络例如包括近场局域网、非近场局域网和/或非局域网。近场通信(nearfieldcommunication,nfc)又称近距离无线通信,是一种短距离的高频无线通信技术,允许设备之间在彼此靠近的情况下进行非接触式点对点数据交互。
本实施例中,近场局域网例如可以通过一个设备创建ap热点,其他设备加入该ap热点而形成的局域网,又例如可以通过一个设备创建wifi直连go(groupowner,组所有者),其他设备作为gc(groupclient,组客户端)加入到该go而形成的局域网,又例如可以通过蓝牙、红外等近距离连接方式形成的局域网。
本实施例中,第一设备为文件共享存储网络中接收到存储目标文件请求的设备,可见,文件共享存储网络中任一接收到存储目标文件请求的设备均为第一设备。
本实施例中,第二设备由第一设备从文件共享存储网络包括的各设备中选取,选取规则可预先设置,例如第二设备为文件共享存储网络中与第一设备建立可信关系的设备,可信关系例如为“好友”。
本实施例中,若第一设备将自身作为共享存储目标文件的设备,则第一设备可以选取一个第二设备,也可以选取多个第二设备;若第一设备不将自身作为共享存储目标文件的设备,则第一设备应当选取多个第二设备。
102、所述第一设备对所述目标文件进行分割,生成多个数据包。
本实施例中,生成的数据包的个数为共享存储所述目标文件的设备的个数。
本实施例中,所述数据包携带有分割信息;所述分割信息包括:第一指示信息;所述第一指示信息是所述第一设备根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的。可见,第一指示信息同时具备目标文件信息与设备信息,可唯一指示共享存储目标文件的设备,也可以将第一指示信息理解为共享存储所述目标文件的设备的id。
本实施例中,当设备为手机时,第一指示信息可以是加入时间的哈希值加手机imei(internationalmobileequipmentidentity,国际移动设备身份码)再加目标文件的文件标识码。
本实施例中,可将目标文件进行平均分割,即生成的数据包携带的数据内容的大小相同;可将目标文件进行不均等分割,即生成的数据包携带的数据内容的大小不同。
103、所述第一设备将与各第二设备对应的数据包发送给各自对应的第二设备进行存储。
可见,对于不同的目标文件,第一设备可以选择不同的第二设备,也可以选择相同的第二设备,当选择相同的第二设备时,第一设备分配给该第二设备的第一指示信息不同,也即第一设备分配给该第二设备的id不同,不同id指示不同的目标文件。
可见,本发明实施例提出的文件存储方法,通过将待存储的文件分割成多份,每份存储在不同的设备上并利用设备标识与文件标识进行唯一指示,实现文件存储,适用于安全性比较高的场景,防止数据被泄露或者窃取。
文件存储方法第二实施例
本实施例公开一种文件存储方法,如图2所示,可包括以下步骤201~203:
201、第一设备在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备。
202、所述第一设备对所述目标文件进行分割,生成多个数据包。
本实施例中,所述数据包携带有分割信息;所述分割信息包括:第一指示信息和第二指示信息;所述第一指示信息是所述第一设备根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
203、所述第一设备将与各第二设备对应的数据包发送给各自对应的第二设备进行存储。
与第一实施例的区别在于:本实施例中,分割信息不仅包括第一指示信息,还包括第二指示信息,用于指示数据包携带的数据内容的分割序号。数据包携带的数据内容可理解为对目标文件进行分割后得到的多个文件分片中的任一文件分片所对应的数据内容。
本实施例中,分割序号用来指示数据包携带的数据内容的分割顺序,本实施例不限定分割序号的具体表示形式,例如可以为数字,字母或自定义顺序编号。
本实施例中,步骤201和203与第一实施例中步骤101和103相同,本实施例不再赘述。
文件存储方法第三实施例
本实施例公开一种文件存储方法,包括两个方案:第一方案和第二方案,具体说明如下:
第一方案,在第一实施例的基础上,本实施例公开的文件存储方法还包括图1中未示出的如下步骤104:
104、所述第一设备存储第一对应关系以及第二对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
本实施例中,第一对应关系可理解为目标文件与各id的对应关系,第二对应关系可理解为各id与各分割序号的对应关系。
本实施例中,第一设备通过存储第一对应关系以及第二对应关系,便于后续对目标文件的恢复。
本实施例中,第一设备可对存储的第一对应关系以及第二对应关系进行加密,保证安全性。
第二方案,在第二实施例的基础上,本实施例公开的文件存储方法还包括图2中未示出的如下步骤204:
204、所述第一设备存储第一对应关系以及第二对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
本实施例中,步骤204与第一方案中的步骤104相同,不再赘述。
文件存储方法第四实施例
本实施例公开一种文件存储方法,在第二实施例的基础上,本实施例公开的文件存储方法还包括图2中未示出的如下步骤204’:
204’、所述第一设备存储第一对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系。
与第三实施例第二方案的区别在于:本实施例中,第一设备仅存储第一对应关系,即仅存储目标文件与各id的对应关系,而不存储第二对应关系,即不存储各id与各分割序号的对应关系,原因参见图2所示步骤202,步骤202中生成的数据包携带有分割信息;分割信息包括:第一指示信息和第二指示信息;第一指示信息理解为id,第二指示信息理解为分割序号,可见,数据包中已经包含了id与分割序号的对应关系,第一设备在恢复目标文件时,基于数据包携带的分割信息,即可合成目标文件,因此,本实施例中,第一设备仅存储第一对应关系。
本实施例中,第一设备可对存储的第一对应关系进行加密,保证安全性。
文件存储方法第五实施例
本实施例公开一种文件存储方法,在第二实施例的基础上,本实施例公开的文件存储方法还包括图2中未示出的如下步骤205:
205、所述第一设备存储第一对应关系以及第三对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系;所述数据包的标识信息为所述第一设备基于该数据包生成的标识信息。
需要说明的是,数字205仅为步骤标识,无其他指示作用,本领域技术人员应理解步骤205之前不存在步骤204。
本实施例中,数据包的标识信息例如为md5值,第三对应关系可理解为各id与各md5值的对应关系。
本实施例中,由于步骤202中生成的数据包携带有分割信息;分割信息包括:第一指示信息和第二指示信息;第一指示信息理解为id,第二指示信息理解为分割序号,可见,数据包中已经包含了id与分割序号的对应关系,因此,本实施例中,第一设备仅存储第一对应关系,不存储第二对应关系。
本实施例中,第一设备通过存储第一对应关系和第三对应关系,便于后续对目标文件的恢复。
本实施例中,第一设备可对存储的第一对应关系以及第三对应关系进行加密,保证安全性。
文件存储方法第六实施例
本实施例公开一种文件存储方法,在第一实施例的基础上,本实施例公开的文件存储方法还包括图1中未示出的如下步骤105:
105、所述第一设备存储第一对应关系、第二对应关系以及第三对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号;所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系;所述数据包的标识信息为所述第一设备基于该数据包生成的标识信息。
需要说明的是,数字105仅为步骤标识,无其他指示作用,本领域技术人员应理解步骤105之前不存在步骤104。
本实施例中,由于步骤201中生成的数据包携带有分割信息;分割信息仅包括第一指示信息;第一指示信息理解为id,因此,本实施例中,第一设备必须同时存储第一对应关系和第二对应关系,否则无法恢复目标文件。
文件存储方法第七实施例
分别在第三实施例、第四实施例、第五实施例和第六实施例的基础上,本实施例公开的文件存储方法还包括:第一设备将存储的所有对应关系发送给各第二设备进行存储。
本实施例中,第二设备在存储接收到的对应关系时可进行加密,且不同的第二设备可采用不同的加密算法进行加密,以进一步提高安全性。
可见,本实施例中,由于第一设备将存储的所有对应关系发送给各第二设备进行存储,因此,恢复目标文件的设备可以为第一设备和各第二设备中的任一设备,而对于第三实施例、第四实施例、第五实施例和第六实施例,仅能通过第一设备来恢复目标文件。
可见,本实施例中,第一设备通过将存储的所有对应关系发送给各第二设备进行存储,使得各第二设备也具有恢复目标文件的基础,增加了目标文件恢复的灵活性。
文件存储方法第八实施例
本实施例公开一种文件存储方法,如图3所示,可包括以下步骤301~303:
301、第一设备在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备。
302、所述第一设备对所述目标文件进行分割,生成多个数据包。
本实施例中,所述数据包携带有分割信息以及数据加密信息。
本实施例中,所述分割信息包括第一指示信息;或者所述分割信息包括第一指示信息和第二指示信息;所述第一指示信息是所述第一设备根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
303、所述第一设备将与各第二设备对应的数据包发送给各自对应的第二设备进行存储。
与第一实施例和第二实施例的区别在于:本实施例中,数据包不仅携带有分割信息,还携带有数据加密信息。
本实施例中,数据加密信息例如为加密算法,数据加密信息为数据包携带的数据内容的加密信息。
本实施例中,不同数据包携带的数据加密信息可以相同,也可以不同。
本实施例中,步骤301和303与第一实施例中步骤101和103相同,本实施例不再赘述。
文件存储方法第九实施例
本实施例公开一种文件存储方法,包括两个方案:第一方案和第二方案,具体说明如下:
第一方案,在第八实施例中分割信息包括第一指示信息和第二指示信息的基础上,本实施例公开的文件存储方法还包括图3中未示出的如下步骤304:
304、所述第一设备存储第一对应关系以及第四对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第四对应关系为各分割信息以及各数据加密信息之间的对应关系。
第二方案,在第八实施例中分割信息仅包括第一指示信息的基础上,本实施例公开的文件存储方法还包括图3中未示出的如下步骤304’:
304’、所述第一设备存储第一对应关系、第二对应关系以及第四对应关系。
其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
文件存储方法第十实施例
本实施例公开一种文件存储方法,包括两个方案:第一方案和第二方案,具体说明如下:
第一方案,在第八实施例中分割信息包括第一指示信息和第二指示信息的基础上,本实施例公开的文件存储方法还包括图3中未示出的如下步骤305:
305、所述第一设备存储第一对应关系以及第三对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系;所述数据包的标识信息为所述第一设备基于该数据包生成的标识信息。
需要说明的是,数字305仅为步骤标识,无其他指示作用,本领域技术人员应理解步骤305之前不存在步骤304。
与第五实施例的区别在于,第一方案中数据包还携带有数据加密信息。
第二方案,在第八实施例中分割信息仅包括第一指示信息的基础上,本实施例公开的文件存储方法还包括图3中未示出的如下步骤305’:
305’、所述第一设备存储第一对应关系、第二对应关系以及第三对应关系。
其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
需要说明的是,数字305’仅为步骤标识,无其他指示作用,本领域技术人员应理解步骤305’之前不存在步骤304’。
与第六实施例的区别在于,第二方案中数据包还携带有数据加密信息。
文件存储方法第十一实施例
在第九实施例的基础上,本实施例公开的文件存储方法还包括:第一设备将所述第一对应关系以及第四对应关系发送给各第二设备进行存储。
可见,本实施例中,由于第一设备将所述第一对应关系以及第四对应关系发送给各第二设备进行存储,因此,恢复目标文件的设备可以为第一设备和各第二设备中的任一设备,而对于第九实施例,仅能通过第一设备来恢复目标文件。
可见,本实施例中,第一设备将所述第一对应关系以及第四对应关系发送给各第二设备进行存储,使得各第二设备也具有恢复目标文件的基础,增加了目标文件恢复的灵活性。
文件存储方法第十二实施例
在第十实施例的基础上,本实施例公开的文件存储方法还包括:第一设备将所述第一对应关系、第二对应关系以及第三对应关系发送给各第二设备进行存储。
可见,本实施例中,由于第一设备将所述第一对应关系、第二对应关系以及第三对应关系发送给各第二设备进行存储,因此,恢复目标文件的设备可以为第一设备和各第二设备中的任一设备,而对于第十实施例,仅能通过第一设备来恢复目标文件。
可见,本实施例中,第一设备将所述第一对应关系、第二对应关系以及第三对应关系发送给各第二设备进行存储,使得各第二设备也具有恢复目标文件的基础,增加了目标文件恢复的灵活性。
文件存储方法第十三实施例
本实施例公开一种文件存储方法,在第一实施例的基础上,本实施例中,数据包还携带有第三指示信息,所述第三指示信息用于指示存储所述数据包对应的文件名后缀信息。
本实施例中,由于数据包携带有第三指示信息,用于指示存储所述数据包对应的文件名后缀信息,因此,接收到数据包的设备会将数据包存储成具有所述文件名以及所述文件名后缀的文件。存储数据包的设备可以基于所述文件名后缀来判断存储的数据包是否为某个目标文件分割出来的文件分片对应的数据包。
本实施例中,由于数据包携带有第三指示信息,使得数据包具备迁移的能力,存储数据包的设备可将数据包拷贝到其它设备上,其他设备也能识别出该数据包为某个目标文件分割出来的文件分片对应的数据包,同时也能识别出该数据包携带的分割信息,利于后续目标文件的恢复。
需要说明的是,文件存储方法第七实施例、第十一实施例和第十二实施例中,第一设备是将存储的所有对应关系发送给个第二设备进行存储,使得各第二设备具有恢复目标文件的基础,为了进一步增加恢复目标文件的灵活性,第一设备可将存储的所有对应关系发送给文件共享存储网络中的所有设备,使得文件共享存储网络中任一设备均可恢复目标文件。
文件提取方法第一实施例
本实施例公开一种文件提取方法,如图4所示,可包括以下步骤401至405:
401、第三设备在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送第一提取请求;所述第一提取请求中携带有所述目标文件对应的所有第一指示信息。
本实施例中,若采用固定设备恢复目标文件(例如文件存储方法第三实施例至第六实施例、第九实施例、第十实施例),则第三设备即为第一设备;若采用不固定设备恢复目标文件(例如文件存储方法第七实施例、第十一实施例和第十二实施例),则第三设备可以为所有第二设备中的任一设备,也可以为文件共享存储网络中任一设备。
本实施例中,第一指示信息是第一设备根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的,所述第一设备为接收到存储所述目标文件的设备。
本实施例中,第三设备也是文件共享存储网络中的设备,步骤401所述向文件共享存储网络中的各设备分别发送第一提取请求,具体为向文件共享存储网络中除第三设备之外的其余各设备分别发送第一提取请求。
本实施例中,第三设备需要从本地存储的各对应关系中查找并确定所述目标文件对应的所有第一指示信息。
402、所述第三设备接收各第四设备反馈的提取响应;所述第四设备为接收到所述第一提取请求且确定本地存储有任一个所述第一指示信息的设备;所述提取响应携带有校验信息;所述校验信息为所述第四设备基于本地存储的第一指示信息对应的数据包生成的校验信息。
403、所述第三设备对各校验信息进行校验,在各校验信息校验成功后,向各第四设备发送第二提取请求;所述第二提取请求中携带有各第四设备本地存储的第一指示信息。
本实施例中,由于校验信息为第四设备基于本地存储的第一指示信息对应的数据包生成的校验信息,因此,校验信息可理解为基于第一指示信息生成的信息,第三设备对各校验信息校验,相当于对基于设备标识与文件标识生成的第一指示信息进行校验。
404、所述第三设备接收各第四设备反馈的本地存储的第一指示信息对应的数据包。
405、所述第三设备基于接收到的各数据包,生成所述目标文件。
可见,本实施例提出文件提取方法,第三设备首先向文件共享存储网络中的各设备发送第一提取请求,第一提取请求中携带有目标文件对应的所有第一指示信息,从而使得存储有任一个第一指示信息的设备反馈校验信息;然后第三设备对校验信息进行校验,校验成功后,向校验成功的对应设备发送第二提取请求,第二提取请求中携带有校验成功的对应设备存储的第一指示信息,以使该设备反馈该第一指示信息对应的数据包;最后第三设备进而基于反馈的各数据包生成目标文件,由于目标文件被分割保存到不同设备,即使有一个设备被侵入,也不会导致目标文件被恢复及提取,适用于安全性比较高的场景,防止数据被泄露或者窃取。
文件提取方法第二实施例
本实施例公开一种文件提取方法,在文件提取方法第一实施例的基础上,本实施例公开的文件提取方法中,所述第一提取请求为所述第三设备基于本地存储的第一对应关系生成的提取请求;所述第一对应关系为所述目标文件与各第一指示信息的对应关系。
可见,本实施例对第三设备进行了限定,限定可提取目标文件的设备为存储有第一对应关系的设备,若没有存储第一对应关系的设备接收到提取目标文件的请求,该设备应当给出拒绝提取的提示信息。
文件提取方法第三实施例
本实施例公开一种文件提取方法,包括两种方案:第一方案和第二方案,具体说明如下:
第一方案,在文件提取方法第一实施例的基础上,本实施例公开的文件提取方法中,所述校验信息包括第一指示信息;
步骤403所述第三设备对各校验信息进行校验,包括:
所述第三设备判断所述校验信息包括的第一指示信息是否为所述目标文件对应的第一指示信息;若是,则校验成功。
第二方案,在文件提取方法第二实施例的基础上,本实施例公开的文件提取方法中,所述校验信息包括第一指示信息;
步骤403所述第三设备对各校验信息进行校验,包括:
所述第三设备判断所述校验信息包括的第一指示信息是否为所述目标文件对应的第一指示信息;若是,则校验成功。
可见,第一方案是针对文件存储方法第三实施例的一种文件提取方法,第二方案是针对文件存储方法第四实施例的一种文件提取方法,两种方案的共同点在于校验信息仅包括第一指示信息,不同点在于,第一方案中数据包仅携带包括第一指示信息,即id,而第二方案中数据包携带第一指示信息和第二指示信息,即id和分割序号。
本实施例公开的两个方案,通过对第一指示信息校验,可确定存储有目标文件分片的各设备,进而从存储有目标文件分片的各设备获取目标文件分片,并基于目标文件分片合成目标文件。
文件提取方法第四实施例
本实施例公开一种文件提取方法,基于文件提取方法第三实施例,本实施例公开的文件提取方法,步骤405所述第三设备基于接收到的各数据包,生成所述目标文件,包括图4中未示出的步骤a1和a2:
a1、所述第三设备基于存储的第二对应关系,确定所述各数据包携带的数据内容的分割序号;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
a2、所述第三设备基于所述各数据包携带的数据内容的分割序号,将所述各数据包携带的数据内容组合成所述目标文件。
可见,本实施例是针对文件存储方法第三实施例的一种文件提取方法,本实施例中,不论数据包是否携带第二指示信息,即分割序号,本实施例中第三设备均存储第二对应关系,即各id与各分割序号的对应关系,以防止数据包携带的分割序号由于干扰出错导致无法合成目标文件的问题。
文件提取方法第五实施例
本实施例公开一种文件提取方法,基于文件提取方法第三实施例,本实施例公开的文件提取方法,所述各数据包还携带有第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号;步骤405所述第三设备基于接收到的各数据包,生成所述目标文件,包括图4中未示出的步骤b1和b2:
b1、所述第三设备基于所述各数据包携带的第二指示信息,确定所述各数据包携带的数据内容的分割序号。
b2、所述第三设备基于所述各数据包携带的数据内容的分割序号,将所述各数据包携带的数据内容组合成所述目标文件。
可见,本实施例是针对文件存储方法第四实施例的一种文件提取方法,本实施例中,由于数据包携带有第二指示信息,即分割序号,本实施例中第三设备可不用存储第二对应关系,即各id与各分割序号的对应关系,第二对应关系对于本实施例来说属于冗余信息,第三设备不需要查找第二对应关系,直接基于各数据包携带的第二指示信息,快速确定各数据包携带的数据内容的分割序号,进而提高了合成目标文件速度。
文件提取方法第六实施例
本实施例公开一种文件提取方法,在文件提取方法第一实施例或第二实施例的基础上,本实施例公开的文件提取方法中,所述校验信息包括第一指示信息以及第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
步骤403所述第三设备对各校验信息进行校验,包括:
所述第三设备判断存储的第二对应关系中是否存在所述校验信息指示的第一指示信息以及第二指示信息的对应关系;若存在,则校验成功;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系。
可见,本实施例是针对文件存储方法第三实施例第二方案的一种文件提取方法,本实施例中,第三设备存储有第二对应关系,即各id与各分割序号的对应关系,以防止数据包携带的分割序号由于干扰出错导致无法合成目标文件的问题。
文件提取方法第七实施例
本实施例公开一种文件提取方法,基于文件提取方法第六实施例,本实施例公开的文件提取方法,步骤405所述第三设备基于接收到的各数据包,生成所述目标文件,包括图4中未示出的步骤c1和c2:
c1、所述第三设备基于所述第二对应关系,确定所述各数据包携带的数据内容的分割序号;
c2、所述第三设备基于所述各数据包携带的数据内容的分割序号,将所述各数据包携带的数据内容组合成所述目标文件。
可见,本实施例是针对文件存储方法第三实施例第二方案的一种文件提取方法,本实施例中,第三设备基于存储的第二对应关系,即各id与各分割序号的对应关系,确定各数据包携带的数据内容的分割序号,保证目标文件分片合成的顺序正确。
文件提取方法第八实施例
本实施例公开一种文件提取方法,本实施例公开一种文件提取方法,包括两种方案:第一方案和第二方案,具体说明如下:
第一方案,在文件提取方法第一实施例的基础上,本实施例公开的文件提取方法中,所述校验信息包括:第一指示信息以及数据包的标识信息;
步骤403所述第三设备对各校验信息进行校验,包括:
所述第三设备判断存储的第三对应关系中是否存在所述校验信息指示的第一指示信息以及数据包的标识信息的对应关系;若存在,则校验成功;其中,所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系。
第二方案,在文件提取方法第二实施例的基础上,本实施例公开的文件提取方法中,所述校验信息包括:第一指示信息以及数据包的标识信息;
步骤403所述第三设备对各校验信息进行校验,包括:
所述第三设备判断存储的第三对应关系中是否存在所述校验信息指示的第一指示信息以及数据包的标识信息的对应关系;若存在,则校验成功;其中,所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系。
可见,第一方案是针对文件存储方法第五实施例的一种文件提取方法,第二方案是针对文件存储方法第六实施例的一种文件提取方法,两种方案的共同点在于校验信息包括第一指示信息以及数据包的标识信息,不同点在于,第一方案中数据包携带第一指示信息和第二指示信息,即id和分割序号,而第二方案中数据包仅携带第一指示信息,即id。
文件提取方法第九实施例
本实施例公开一种文件提取方法,在文件提取方法第八实施例的基础上,本实施例公开的文件提取方法,所述各数据包携带有第二指示信息,所述第二指示信息用于指示数据包携带的数据内容的分割序号;步骤405所述第三设备基于接收到的各数据包,生成所述目标文件,包括图4中未示出的步骤d1和d2:包括:
d1、所述第三设备基于所述各数据包携带的第二指示信息,确定所述各数据包携带的数据内容的分割序号;
d2、所述第三设备基于所述各数据包携带的数据内容的分割序号,将所述各数据包携带的数据内容组合成所述目标文件。
可见,本实施例是针对文件存储方法第五实施例的一种文件提取方法,本实施例中,由于数据包携带有第二指示信息,即分割序号,本实施例中第三设备可不用存储第二对应关系,即各id与各分割序号的对应关系,第二对应关系对于本实施例来说属于冗余信息,第三设备不需要查找第二对应关系,直接基于各数据包携带的第二指示信息,快速确定各数据包携带的数据内容的分割序号,进而提高了合成目标文件速度。
文件提取方法第十实施例
本实施例公开一种文件提取方法,在文件提取方法第八实施例基础上,本实施例公开的文件提取方法,步骤405所述第三设备基于接收到的各数据包,生成所述目标文件,包括图4中未示出的步骤e1和e2:
e1、所述第三设备基于存储的第二对应关系,确定所述各数据包携带的数据内容的分割序号;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
e2、所述第三设备基于所述各数据包携带的数据内容的分割序号,将所述各数据包携带的数据内容组合成所述目标文件。
可见,本实施例是针对文件存储方法第六实施例的一种文件提取方法,本实施例中,由于数据包不携带第二指示信息,即分割序号,因此,第三设备需存储第二对应关系,即各id与各分割序号的对应关系,第三设备查找第二对应关系,确定各数据包携带的数据内容的分割序号,保证目标文件分片合成的顺序正确。
文件提取方法第十一实施例
本实施例公开一种文件提取方法,在文件提取方法第一实施例或第二实施例的基础上,本实施例公开的文件提取方法中,所述校验信息包括:分割信息以及数据加密信息;所述分割信息包括第一指示信息;
步骤403所述第三设备对各校验信息进行校验,包括:
所述第三设备判断存储的第四对应关系中是否存在所述校验信息指示的分割信息以及数据加密信息之间的对应关系;若存在,则校验成功;其中,所述第四对应关系为各分割信息以及各数据加密信息的对应关系。
可见,本实施例是针对文件存储方法第九实施例的一种文件提取方法,本实施例中分割信息包括第一指示信息,即id,第四对应关系即各id与各数据加密信息的对应关系,校验信息包括分割信息以及数据加密信息,即id和数据加密信息,说明数据包中携带有数据加密信息,因此,可利用数据包中携带的数据加密信息对应得解密算法对数据包携带的数据内容进行解密,得到目标文件分片。
文件提取方法第十二实施例
本实施例公开一种文件提取方法,在文件提取方法第十一实施例的基础上,本实施例公开的文件提取方法,所述各数据包还携带有数据加密信息;步骤405所述第三设备基于接收到的各数据包,生成所述目标文件,包括图4中未示出的步骤f1和f2:
f1、所述第三设备基于存储的第二对应关系,确定所述各数据包携带的数据内容的分割序号;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
f2、所述第三设备基于所述各数据包携带的数据内容的分割序号以及所述各数据包携带的数据加密信息,将所述各数据包携带的数据内容组合成所述目标文件。
本实施例中,由于第三设备存储有第二对应关系,即各id与各分割序号的对应关系,因此,数据包携带的分割信息可包括第一指示信息,也可包括第一指示信息和第二指示信息。也即,不论数据包携带的分割信息是否包括第二指示信息,本实施例中,第三设备均存储第二对应关系,即各id与各分割序号的对应关系,以防止分割信息包括的分割序号由于干扰出错导致无法合成目标文件的问题。
文件提取方法第十三实施例
本实施例公开一种文件提取方法,在文件提取方法第十一实施例的基础上,本实施例公开的文件提取方法,所述分割信息还包括第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号;所述各数据包还携带有所述数据加密信息;步骤405所述第三设备基于接收到的各数据包,生成所述目标文件,包括图4中未示出的步骤g1和g2:
g1、所述第三设备基于所述各数据包携带的分割信息中的第二指示信息,确定所述各数据包携带的数据内容的分割序号;
g2、所述第三设备基于所述各数据包携带的数据内容的分割序号以及所述各数据包携带的数据加密信息,将所述各数据包携带的数据内容组合成所述目标文件。
本实施例中,由于数据包携带的分割信息包括第一指示信息和第二指示信息,因此本实施例中第三设备可不用存储第二对应关系,即各id与各分割序号的对应关系,第二对应关系对于本实施例来说属于冗余信息,第三设备不需要查找第二对应关系,直接基于各数据包携带的第二指示信息,快速确定各数据包携带的数据内容的分割序号,进而提高了合成目标文件速度。
文件提取方法第十四实施例
本实施例公开一种文件提取方法,在文件提取方法第一实施例或第二实施例的基础上,本实施例公开的文件提取方法中,所述校验信息包括:第一指示信息以及数据包的标识信息;所述数据包携带有数据加密信息;
步骤403所述第三设备对各校验信息进行校验,包括:
所述第三设备判断存储的第三对应关系中是否存在所述校验信息指示的第一指示信息以及数据包的标识信息的对应关系;若存在,则校验成功;其中,所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系。
本实施例是针对文件存储方法第十实施例的一种文件提取方法,第三设备预先存储第三对应关系,即各id与各md5值的对应关系。各数据包携带第一指示信息、第二指示信息和数据加密信息,或者各数据包携带第一指示信息和数据加密信息。
文件提取方法第十五实施例
本实施例公开一种文件提取方法,在文件提取方法第十四实施例的基础上,本实施例公开的文件提取方法中,步骤405所述第三设备基于接收到的各数据包,生成所述目标文件,包括图4中未示出的步骤h1和h2:
h1、所述第三设备基于存储的第二对应关系,确定所述各数据包携带的数据内容的分割序号;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
h2、所述第三设备基于所述各数据包携带的数据内容的分割序号以及所述各数据包携带的数据加密信息,将所述各数据包携带的数据内容组合成所述目标文件。
本实施例是针对文件存储方法第十实施例第二方案的一种文件提取方法。
文件提取方法第十六实施例
本实施例公开一种文件提取方法,在文件提取方法第十四实施例的基础上,本实施例公开的文件提取方法中,所述各数据还携带有第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
所述第三设备基于接收到的各数据包,生成所述目标文件,包括:
所述第三设备基于所述各数据包携带的第二指示信息,确定所述各数据包携带的数据内容的分割序号;
所述第三设备基于所述各数据包携带的数据内容的分割序号以及所述各数据包携带的数据加密信息,将所述各数据包携带的数据内容组合成所述目标文件。
本实施例是针对文件存储方法第十实施例的一种文件提取方法。
文件提取方法第十七实施例
本实施例公开一种文件提取方法,如图5所示,可包括以下步骤501至503:
501、第三设备在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送提取请求;所述提取请求中携带有所述目标文件对应的所有第一指示信息。
本实施例中,步骤501与文件提取方法第一实施例的步骤401相同,具体描述可参见文件提取方法第一实施例,本实施例不再赘述。
502、所述第三设备接收各第四设备反馈的数据包;所述第四设备为接收到所述提取请求且确定本地存储有任一个所述第一指示信息的设备。
本实施例中,各第四设备在接收到所述提取请求且确定本地存储有任一个所述第一指示信息时,直接将该第一指示信息对应的数据包发送给第三设备。
503、所述第三设备对各数据包携带的分割信息进行校验,在各分割信息校验成功后,基于接收到的各数据包,生成所述目标文件;其中,所述分割信息包括第一指示信息。
本实施例中,第一指示信息是第一设备根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的,所述第一设备为接收到存储所述目标文件的设备。
可见,本实施例提出文件提取方法,对基于设备标识与文件标识生成的指示信息进行校验,确定存储有文件分片的各设备,从而基于文件分片对应的分割序号,将各文件分片合成为待提取的文件,实现文件提取,适用于安全性比较高的场景,防止数据被泄露或者窃取。
文件提取方法第十八实施例
本实施例公开一种文件提取方法,在文件提取方法第十七实施例的基础上,本实施例公开的文件提取方法中,所述提取请求为所述第三设备基于本地存储的第一对应关系生成的提取请求;所述第一对应关系为所述目标文件与各第一指示信息的对应关系。
可见,本实施例对第三设备进行了限定,限定可提取目标文件的设备为存储有第一对应关系的设备,若没有存储第一对应关系的设备接收到提取目标文件的请求,该设备应当给出拒绝提取的提示信息。
文件提取方法第十九实施例
本实施例公开一种文件提取方法,在文件提取方法第十七实施例或第十八实施例的基础上,本实施例公开的文件提取方法中,步骤503所述第三设备对各数据包携带的分割信息进行校验,包括:
所述第三设备判断所述分割信息包括的第一指示信息是否为所述目标文件对应的第一指示信息;若是,则校验成功。
可见,本实施例是针对文件存储方法第三实施例和第四实施例的一种文件提取方法,通过对第一指示信息校验,可确定存储有目标文件分片的各设备,进而从存储有目标文件分片的各设备获取目标文件分片,并基于目标文件分片合成目标文件。
文件提取方法第二十实施例
本实施例公开一种文件提取方法,在文件提取方法第十九实施例的基础上,本实施例公开的文件提取方法中,步骤503所述基于接收到的各数据包,生成所述目标文件,包括k1和k2:
k1、所述第三设备基于存储的第二对应关系,确定所述各数据包携带的数据内容的分割序号;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
k2、所述第三设备基于所述各数据包携带的数据内容的分割序号,将所述各数据包携带的数据内容组合成所述目标文件。
本实施例是针对文件存储方法第三实施例的一种文件提取方法。
文件提取方法第二十一实施例
本实施例公开一种文件提取方法,在文件提取方法第十九实施例的基础上,本实施例公开的文件提取方法中,所述分割信息还包括:第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
步骤503所述基于接收到的各数据包,生成所述目标文件,包括l1和l2:
l1、所述第三设备基于所述各数据包携带的分割信息中的第二指示信息,确定所述各数据包携带的数据内容的分割序号;
l2、所述第三设备基于所述各数据包携带的数据内容的分割序号,将所述各数据包携带的数据内容组合成所述目标文件。
本实施例是针对文件存储方法第四实施例的一种文件提取方法。
文件提取方法第二十二实施例
本实施例公开一种文件提取方法,在文件提取方法第十七实施例或第十八实施例的基础上,本实施例公开的文件提取方法中,所述分割信息还包括:第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
步骤503所述第三设备对各数据包携带的分割信息进行校验,包括:
所述第三设备判断存储的第二对应关系中是否存在所述分割信息指示的第一指示信息以及第二指示信息的对应关系;若存在,则校验成功;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系。
本实施例是针对文件存储方法第三实施例第二方案的一种文件提取方法。
文件提取方法第二十三实施例
本实施例公开一种文件提取方法,在文件提取方法第二十二实施例的基础上,本实施例公开的文件提取方法中,步骤503所述基于接收到的各数据包,生成所述目标文件,包括m1和m2:
m1、所述第三设备基于所述第二对应关系,确定所述各数据包携带的数据内容的分割序号;
m2、所述第三设备基于所述各数据包携带的数据内容的分割序号,将所述各数据包携带的数据内容组合成所述目标文件。
本实施例是针对文件存储方法第三实施例第二方案的一种文件提取方法。
文件提取方法第二十四实施例
本实施例公开一种文件提取方法,在文件提取方法第十七实施例或第十八实施例的基础上,本实施例公开的文件提取方法中,所述各数据包还携带有数据加密信息。
步骤503所述第三设备对各数据包携带的分割信息进行校验,包括:
所述第三设备判断存储的第四对应关系中是否存在所述各数据包携带的分割信息以及数据加密信息之间的对应关系;若存在,则校验成功;其中,所述第四对应关系为各分割信息以及各数据加密信息的对应关系。
本实施例是针对文件存储方法第九实施例的一种文件提取方法。
文件提取方法第二十五实施例
本实施例公开一种文件提取方法,在文件提取方法第二十四实施例的基础上,本实施例公开的文件提取方法中,步骤503所述基于接收到的各数据包,生成所述目标文件,包括n1和n2:
所述第三设备基于存储的第二对应关系,确定所述各数据包携带的数据内容的分割序号;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
所述第三设备基于所述各数据包携带的数据内容的分割序号以及所述各数据包携带的数据加密信息,将所述各数据包携带的数据内容组合成所述目标文件。
本实施例是针对文件存储方法第九实施例的一种文件提取方法。本实施例中,分割信息包括第一指示信息,或分割信息包括第一指示信息和第二指示信息。
文件提取方法第二十六实施例
本实施例公开一种文件提取方法,在文件提取方法第二十四实施例的基础上,本实施例公开的文件提取方法中,所述分割信息还包括第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
步骤503所述第三设备基于接收到的各数据包,生成所述目标文件,包括p1和p2:
p1、所述第三设备基于所述各数据包携带的分割信息中的第二指示信息,确定所述各数据包携带的数据内容的分割序号;
p2、所述第三设备基于所述各数据包携带的数据内容的分割序号以及所述各数据包携带的数据加密信息,将所述各数据包携带的数据内容组合成所述目标文件。
图6示出了本发明实施例提供的一种文件存储装置,可包括以下单元:确定单元61、生成单元62以及第一发送单元63,各单元具体说明如下:
确定单元61,用于在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备;
生成单元62,用于对所述目标文件进行分割,生成多个数据包;
第一发送单元63,用于将与各第二设备对应的数据包发送给各自对应的第二设备进行存储;
其中,所述数据包携带有分割信息;所述分割信息包括:第一指示信息;所述第一指示信息是所述第一设备根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的。
本实施例提供的文件存储装置能够实现文件存储方法第一实施例至第十三实施例的各个过程,为避免重复,这里不再赘述。
图7出了本发明实施例提供的一种文件提取装置,可包括以下单元:第一发送单元71、第一接收单元72、第一处理单元73、第二接收单元74和生成单元75,各单元具体说明如下:
第一发送单元71,用于在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送第一提取请求;所述第一提取请求中携带有所述目标文件对应的所有第一指示信息;
第一接收单元72,用于接收各第四设备反馈的提取响应;所述第四设备为接收到所述第一提取请求且确定本地存储有任一个所述第一指示信息的设备;所述提取响应携带有校验信息;所述校验信息为所述第四设备基于本地存储的第一指示信息对应的数据包生成的校验信息;
第一处理单元73,用于对各校验信息进行校验,在各校验信息校验成功后,向各第四设备发送第二提取请求;所述第二提取请求中携带有各第四设备本地存储的第一指示信息;
第二接收单元74,用于接收各第四设备反馈的本地存储的第一指示信息对应的数据包;
生成单元75,用于基于所述第二接收单元接收到的各数据包,生成所述目标文件。
本实施例提供的文件提取装置能够实现文件提取方法第一实施例至第十六实施例的各个过程,为避免重复,这里不再赘述。
图8出了本发明实施例提供的一种文件提取装置,可包括以下单元:第二发送单元81、第三接收单元82和第二处理单元83,各单元具体说明如下:
第二发送单元81,用于在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送提取请求;所述提取请求中携带有所述目标文件对应的所有第一指示信息;
第三接收单元82,用于接收各第四设备反馈的数据包;所述第四设备为接收到所述提取请求且确定本地存储有任一个所述第一指示信息的设备;
第二处理单元83,用于对各数据包携带的分割信息进行校验,在各分割信息校验成功后,基于接收到的各数据包,生成所述目标文件;其中,所述分割信息包括第一指示信息。
本实施例提供的文件提取装置能够实现文件提取方法第十七实施例至第二十六实施例的各个过程,为避免重复,这里不再赘述。
本发明实施例还公开一种计算机程序产品,所述计算机程序产品包括存储在非暂态计算机可读存储介质上的计算机程序,所述计算机程序包括程序指令,当所述程序指令被计算机执行时,计算机能够执行文件存储方法第一实施例至第十三实施例的各个过程,例如包括:
在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备;
对所述目标文件进行分割,生成多个数据包;
将与各第二设备对应的数据包发送给各自对应的第二设备进行存储;
其中,所述数据包携带有分割信息;所述分割信息包括:第一指示信息;所述第一指示信息是根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的。
本发明实施例还提出一种非暂态计算机可读存储介质,所述非暂态计算机可读存储介质存储计算机指令,所述计算机指令使所述计算机执行文件存储方法第一实施例至第十三实施例的各个过程,例如包括:
在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备;
对所述目标文件进行分割,生成多个数据包;
将与各第二设备对应的数据包发送给各自对应的第二设备进行存储;
其中,所述数据包携带有分割信息;所述分割信息包括:第一指示信息;所述第一指示信息是根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的。
图9是本发明另一个实施例的文件存储装置的框图。图9所示的文件存储装置900包括:至少一个处理器901、存储器902、至少一个网络接口904和其他用户接口903。文件存储装置900中的各个组件通过总线系统905耦合在一起。可理解,总线系统905用于实现这些组件之间的连接通信。总线系统905除包括数据总线之外,还包括电源总线、控制总线和状态信号总线。但是为了清楚说明起见,在图9中将各种总线都标为总线系统905。
其中,用户接口903可以包括显示器、键盘或者点击设备(例如,鼠标,轨迹球(trackball)、触感板或者触摸屏等。
可以理解,本发明实施例中的存储器902可以是易失性存储器或非易失性存储器,或可包括易失性和非易失性存储器两者。其中,非易失性存储器可以是只读存储器(read-onlymemory,rom)、可编程只读存储器(programmablerom,prom)、可擦除可编程只读存储器(erasableprom,eprom)、电可擦除可编程只读存储器(electricallyeprom,eeprom)或闪存。易失性存储器可以是随机存取存储器(randomaccessmemory,ram),其用作外部高速缓存。通过示例性但不是限制性说明,许多形式的ram可用,例如静态随机存取存储器(staticram,sram)、动态随机存取存储器(dynamicram,dram)、同步动态随机存取存储器(synchronousdram,sdram)、双倍数据速率同步动态随机存取存储器(doubledataratesdram,ddrsdram)、增强型同步动态随机存取存储器(enhancedsdram,esdram)、同步连接动态随机存取存储器(synchlinkdram,sldram)和直接内存总线随机存取存储器(directrambusram,drram)。本文描述的系统和方法的存储器902旨在包括但不限于这些和任意其它适合类型的存储器。
在一些实施方式中,存储器902存储了如下的元素,可执行单元或者数据结构,或者他们的子集,或者他们的扩展集:操作系统9021和应用程序9022。
其中,操作系统9021,包含各种系统程序,例如框架层、核心库层、驱动层等,用于实现各种基础业务以及处理基于硬件的任务。应用程序9022,包含各种应用程序,例如媒体播放器(mediaplayer)、浏览器(browser)等,用于实现各种应用业务。实现本发明实施例方法的程序可以包含在应用程序9022中。
在本发明实施例中,通过调用存储器902存储的程序或指令,具体的,可以是应用程序9022中存储的程序或指令,处理器901用于执行文件存储方法第一实施例至第十三实施例的各个过程,例如包括:
在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备;
对所述目标文件进行分割,生成多个数据包;
将与各第二设备对应的数据包发送给各自对应的第二设备进行存储;
其中,所述数据包携带有分割信息;所述分割信息包括:第一指示信息;所述第一指示信息是根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的。
上述本发明实施例揭示的方法可以应用于处理器901中,或者由处理器901实现。处理器901可能是一种集成电路芯片,具有信号的处理能力。在实现过程中,上述方法的各步骤可以通过处理器901中的硬件的集成逻辑电路或者软件形式的指令完成。上述的处理器901可以是通用处理器、数字信号处理器(digitalsignalprocessor,dsp)、专用集成电路(applicationspecificintegratedcircuit,asic)、现成可编程门阵列(fieldprogrammablegatearray,fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。结合本发明实施例所公开的方法的步骤可以直接体现为硬件译码处理器执行完成,或者用译码处理器中的硬件及软件单元组合执行完成。软件单元可以位于随机存储器,闪存、只读存储器,可编程只读存储器或者电可擦写可编程存储器、寄存器等本领域成熟的存储介质中。该存储介质位于存储器902,处理器901读取存储器902中的信息,结合其硬件完成上述方法的步骤。
可以理解的是,本文描述的这些实施例可以用硬件、软件、固件、中间件、微码或其组合来实现。对于硬件实现,处理单元可以实现在一个或多个专用集成电路(applicationspecificintegratedcircuits,asic)、数字信号处理器(digitalsignalprocessing,dsp)、数字信号处理设备(dspdevice,dspd)、可编程逻辑设备(programmablelogicdevice,pld)、现场可编程门阵列(field-programmablegatearray,fpga)、通用处理器、控制器、微控制器、微处理器、用于执行本申请所述功能的其它电子单元或其组合中。
对于软件实现,可通过执行本文所述功能的单元来实现本文所述的技术。软件代码可存储在存储器中并通过处理器执行。存储器可以在处理器中或在处理器外部实现。
本发明实施例还公开一种计算机程序产品,所述计算机程序产品包括存储在非暂态计算机可读存储介质上的计算机程序,所述计算机程序包括程序指令,当所述程序指令被计算机执行时,计算机能够执行文件提取方法第一实施例至第十六实施例的各个过程,例如包括:
在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送第一提取请求;所述第一提取请求中携带有所述目标文件对应的所有第一指示信息;
接收各第四设备反馈的提取响应;所述第四设备为接收到所述第一提取请求且确定本地存储有任一个所述第一指示信息的设备;所述提取响应携带有校验信息;所述校验信息为所述第四设备基于本地存储的第一指示信息对应的数据包生成的校验信息;
对各校验信息进行校验,在各校验信息校验成功后,向各第四设备发送第二提取请求;所述第二提取请求中携带有各第四设备本地存储的第一指示信息;
接收各第四设备反馈的本地存储的第一指示信息对应的数据包;
基于接收到的各数据包,生成所述目标文件。
本发明实施例还提出一种非暂态计算机可读存储介质,所述非暂态计算机可读存储介质存储计算机指令,所述计算机指令使所述计算机执行文件提取方法第一实施例至第十六实施例的各个过程,例如包括:
在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送第一提取请求;所述第一提取请求中携带有所述目标文件对应的所有第一指示信息;
接收各第四设备反馈的提取响应;所述第四设备为接收到所述第一提取请求且确定本地存储有任一个所述第一指示信息的设备;所述提取响应携带有校验信息;所述校验信息为所述第四设备基于本地存储的第一指示信息对应的数据包生成的校验信息;
对各校验信息进行校验,在各校验信息校验成功后,向各第四设备发送第二提取请求;所述第二提取请求中携带有各第四设备本地存储的第一指示信息;
接收各第四设备反馈的本地存储的第一指示信息对应的数据包;
基于接收到的各数据包,生成所述目标文件。
图10是本发明另一个实施例的文件提取装置的框图。图10所示的文件提取装置1000包括:至少一个处理器1001、存储器1002、至少一个网络接口1004和其他用户接口1003。文件提取装置1000中的各个组件通过总线系统1005耦合在一起。可理解,总线系统1005用于实现这些组件之间的连接通信。总线系统1005除包括数据总线之外,还包括电源总线、控制总线和状态信号总线。但是为了清楚说明起见,在图10中将各种总线都标为总线系统1005。
在一些实施方式中,存储器1002存储了如下的元素,可执行单元或者数据结构,或者他们的子集,或者他们的扩展集:操作系统10021和应用程序10022。
其中,操作系统10021,包含各种系统程序,例如框架层、核心库层、驱动层等,用于实现各种基础业务以及处理基于硬件的任务。应用程序10022,包含各种应用程序,例如媒体播放器(mediaplayer)、浏览器(browser)等,用于实现各种应用业务。实现本发明实施例方法的程序可以包含在应用程序10022中。
在本发明实施例中,通过调用存储器1002存储的程序或指令,具体的,可以是应用程序10022中存储的程序或指令,处理器1001用于执行文件提取方法第一实施例至第十六实施例的各个过程,例如包括:
在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送第一提取请求;所述第一提取请求中携带有所述目标文件对应的所有第一指示信息;
接收各第四设备反馈的提取响应;所述第四设备为接收到所述第一提取请求且确定本地存储有任一个所述第一指示信息的设备;所述提取响应携带有校验信息;所述校验信息为所述第四设备基于本地存储的第一指示信息对应的数据包生成的校验信息;
对各校验信息进行校验,在各校验信息校验成功后,向各第四设备发送第二提取请求;所述第二提取请求中携带有各第四设备本地存储的第一指示信息;
接收各第四设备反馈的本地存储的第一指示信息对应的数据包;
基于接收到的各数据包,生成所述目标文件。
本实施例中各组成部分的具体说明可参见图9所示的实施例,本实施例不再赘述。
本发明实施例还公开一种计算机程序产品,所述计算机程序产品包括存储在非暂态计算机可读存储介质上的计算机程序,所述计算机程序包括程序指令,当所述程序指令被计算机执行时,计算机能够执行文件提取方法第十七实施例至第二十六实施例的各个过程,例如包括:
在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送提取请求;所述提取请求中携带有所述目标文件对应的所有第一指示信息;
接收各第四设备反馈的数据包;所述第四设备为接收到所述提取请求且确定本地存储有任一个所述第一指示信息的设备;
对各数据包携带的分割信息进行校验,在各分割信息校验成功后,基于接收到的各数据包,生成所述目标文件;其中,所述分割信息包括第一指示信息。
本发明实施例还提出一种非暂态计算机可读存储介质,所述非暂态计算机可读存储介质存储计算机指令,所述计算机指令使所述计算机执行文件提取方法第十七实施例至第二十六实施例的各个过程,例如包括:
在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送提取请求;所述提取请求中携带有所述目标文件对应的所有第一指示信息;
接收各第四设备反馈的数据包;所述第四设备为接收到所述提取请求且确定本地存储有任一个所述第一指示信息的设备;
对各数据包携带的分割信息进行校验,在各分割信息校验成功后,基于接收到的各数据包,生成所述目标文件;其中,所述分割信息包括第一指示信息。
图11是本发明另一个实施例的文件提取装置的框图。图11所示的文件提取装置1100包括:至少一个处理器1101、存储器1102、至少一个网络接口1104和其他用户接口1103。文件提取装置1100中的各个组件通过总线系统1105耦合在一起。可理解,总线系统1105用于实现这些组件之间的连接通信。总线系统1105除包括数据总线之外,还包括电源总线、控制总线和状态信号总线。但是为了清楚说明起见,在图11中将各种总线都标为总线系统1105。
在一些实施方式中,存储器1102存储了如下的元素,可执行单元或者数据结构,或者他们的子集,或者他们的扩展集:操作系统11021和应用程序11022。
其中,操作系统11021,包含各种系统程序,例如框架层、核心库层、驱动层等,用于实现各种基础业务以及处理基于硬件的任务。应用程序11022,包含各种应用程序,例如媒体播放器(mediaplayer)、浏览器(browser)等,用于实现各种应用业务。实现本发明实施例方法的程序可以包含在应用程序11022中。
在本发明实施例中,通过调用存储器1102存储的程序或指令,具体的,可以是应用程序11022中存储的程序或指令,处理器1101用于执行文件提取方法第十七实施例至第二十六实施例的各个过程,例如包括:
在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送提取请求;所述提取请求中携带有所述目标文件对应的所有第一指示信息;
接收各第四设备反馈的数据包;所述第四设备为接收到所述提取请求且确定本地存储有任一个所述第一指示信息的设备;
对各数据包携带的分割信息进行校验,在各分割信息校验成功后,基于接收到的各数据包,生成所述目标文件;其中,所述分割信息包括第一指示信息。
本实施例中各组成部分的具体说明可参见图9所示的实施例,本实施例不再赘述。
本发明实施例公开了:
a1、一种文件存储装置,包括:
确定单元,用于在文件共享存储网络中确定用于共享存储目标文件的至少一个的第二设备;
生成单元,用于对所述目标文件进行分割,生成多个数据包;
第一发送单元,用于将与各第二设备对应的数据包发送给各自对应的第二设备进行存储;
其中,所述数据包携带有分割信息;所述分割信息包括:第一指示信息;所述第一指示信息是所述第一设备根据用于存储该数据包的设备的设备标识以及所述目标文件的文件标识生成的。
a2、根据a1所述的装置,所述分割信息还包括:第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
a3、根据权利要求a1或a2所述的装置,所述装置还包括:
存储单元,用于存储第一对应关系以及第二对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
a4、根据权利要求a2所述的装置,所述装置还包括:
存储单元,用于存储第一对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系。
a5、根据权利要求a2所述的装置,所述装置还包括:
存储单元,用于存储第一对应关系以及第三对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系;所述数据包的标识信息为所述第一设备基于该数据包生成的标识信息。
a6、根据权利要求a1所述的装置,所述装置还包括:
存储单元,用于存储第一对应关系、第二对应关系以及第三对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号;所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系;所述数据包的标识信息为所述第一设备基于该数据包生成的标识信息。
a7、根据权利要求a4至a6任一项所述的装置,所述装置还包括:
第二发送单元,用于将所述存储单元存储的所有对应关系发送给各第二设备进行存储。
a8、根据权利要求a1或a2所述的装置,所述数据包还携带有数据加密信息。
a9、根据权利要求a8所述的装置,所述装置还包括:
存储单元,用于存储第一对应关系以及第四对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第四对应关系为各分割信息以及各数据加密信息之间的对应关系;
若所述分割信息仅包括第一指示信息,则所述存储单元,还用于存储第二对应关系,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
a10、根据权利要求a8所述的装置,所述装置还包括:
存储单元,用于存储第一对应关系以及第三对应关系;
其中,所述第一对应关系为所述目标文件与各第一指示信息的对应关系;所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系;所述数据包的标识信息为所述第一设备基于该数据包生成的标识信息;
若所述分割信息仅包括第一指示信息,则所述存储单元,还用于存储第二对应关系;所述第二对应关系为各第一指示信息与各第二指示信息的对应关系;所述第二指示信息用于指示数据包携带的数据内容的分割序号。
a11、根据权利要求a9所述的装置,所述装置还包括:
第三发送单元,用于将所述第一对应关系以及第四对应关系发送给各第二设备进行存储。
a12、根据权利要求a10所述的装置,所述装置还包括:
第四发送单元,用于将所述第一对应关系、第二对应关系以及第三对应关系发送给各第二设备进行存储。
b1、一种文件提取装置,包括:
第一发送单元,用于在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送第一提取请求;所述第一提取请求中携带有所述目标文件对应的所有第一指示信息;
第一接收单元,用于接收各第四设备反馈的提取响应;所述第四设备为接收到所述第一提取请求且确定本地存储有任一个所述第一指示信息的设备;所述提取响应携带有校验信息;所述校验信息为所述第四设备基于本地存储的第一指示信息对应的数据包生成的校验信息;
第一处理单元,用于对各校验信息进行校验,在各校验信息校验成功后,向各第四设备发送第二提取请求;所述第二提取请求中携带有各第四设备本地存储的第一指示信息;
第二接收单元,用于接收各第四设备反馈的本地存储的第一指示信息对应的数据包;
生成单元,用于基于所述第二接收单元接收到的各数据包,生成所述目标文件。
b2、根据权利要求b1所述的装置,所述第一提取请求为所述第一发送单元基于本地存储的第一对应关系生成的提取请求;所述第一对应关系为所述目标文件与各第一指示信息的对应关系。
b3、根据权利要求b1或b2所述的装置,所述校验信息包括第一指示信息;
所述第一处理单元对各校验信息进行校验,包括:
所述第一处理单元判断所述校验信息包括的第一指示信息是否为所述目标文件对应的第一指示信息;若是,则校验成功。
b4、根据权利要求b1或b2所述的装置,所述校验信息包括第一指示信息以及第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
所述第一处理单元对各校验信息进行校验,包括:
所述第一处理单元判断存储的第二对应关系中是否存在所述校验信息指示的第一指示信息以及第二指示信息的对应关系;若存在,则校验成功;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系。
b5、根据权利要求b1或b2所述的装置,所述校验信息包括:第一指示信息以及数据包的标识信息;
所述第一处理单元对各校验信息进行校验,包括:
所述第一处理单元判断存储的第三对应关系中是否存在所述校验信息指示的第一指示信息以及数据包的标识信息的对应关系;若存在,则校验成功;其中,所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系。
b6、根据权利要求b1或b2所述的装置,所述校验信息包括:分割信息以及数据加密信息;所述分割信息包括第一指示信息;
所述第一处理单元对各校验信息进行校验,包括:
所述第一处理单元判断存储的第四对应关系中是否存在所述校验信息指示的分割信息以及数据加密信息之间的对应关系;若存在,则校验成功;其中,所述第四对应关系为各分割信息以及各数据加密信息之间的对应关系。
b7、根据权利要求b1或b2所述的装置,所述校验信息包括:第一指示信息以及数据包的标识信息;所述数据包携带有数据加密信息;
所述第一处理单元对各校验信息进行校验,包括:
所述第一处理单元判断存储的第三对应关系中是否存在所述校验信息指示的第一指示信息以及数据包的标识信息的对应关系;若存在,则校验成功;其中,所述第三对应关系为各第一指示信息与各数据包的标识信息的对应关系。
c1、一种文件提取装置,包括:
第二发送单元,用于在接收到提取目标文件的请求后,向文件共享存储网络中的各设备分别发送提取请求;所述提取请求中携带有所述目标文件对应的所有第一指示信息;
第三接收单元,用于接收各第四设备反馈的数据包;所述第四设备为接收到所述提取请求且确定本地存储有任一个所述第一指示信息的设备;
第二处理单元,用于对各数据包携带的分割信息进行校验,在各分割信息校验成功后,基于接收到的各数据包,生成所述目标文件;其中,所述分割信息包括第一指示信息。
c2、根据权利要求c1所述的装置,所述提取请求为所述第二发送单元基于本地存储的第一对应关系生成的提取请求;所述第一对应关系为所述目标文件与各第一指示信息的对应关系。
c3、根据权利要求c1或c2所述的装置,所述第二处理单元对各数据包携带的分割信息进行校验,包括:
所述第二处理单元判断所述分割信息包括的第一指示信息是否为所述目标文件对应的第一指示信息;若是,则校验成功。
c4、根据权利要求c1或c2所述的装置,所述分割信息还包括:第二指示信息;所述第二指示信息用于指示数据包携带的数据内容的分割序号;
所述第二处理单元对各数据包携带的分割信息进行校验,包括:
所述第二处理单元判断存储的第二对应关系中是否存在所述分割信息指示的第一指示信息以及第二指示信息的对应关系;若存在,则校验成功;其中,所述第二对应关系为各第一指示信息与各第二指示信息的对应关系。
c5、根据权利要求c1或c2所述的装置,所述各数据包还携带有数据加密信息;
所述第二处理单元对各数据包携带的分割信息进行校验,包括:
所述第二处理单元判断存储的第四对应关系中是否存在所述各数据包携带的分割信息以及数据加密信息之间的对应关系;若存在,则校验成功;其中,所述第四对应关系为各分割信息以及各数据加密信息的对应关系。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统、装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在本申请所提供的实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。
所述功能如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明实施例的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:u盘、移动硬盘、rom、ram、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以权利要求的保护范围为准。