CN116016485A - 文件夹下载的方法及装置 - Google Patents
文件夹下载的方法及装置 Download PDFInfo
- Publication number
- CN116016485A CN116016485A CN202211536863.1A CN202211536863A CN116016485A CN 116016485 A CN116016485 A CN 116016485A CN 202211536863 A CN202211536863 A CN 202211536863A CN 116016485 A CN116016485 A CN 116016485A
- Authority
- CN
- China
- Prior art keywords
- file
- target
- downloading
- page
- folder
- 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
Images
Landscapes
- Information Transfer Between Computers (AREA)
Abstract
本申请公开了一种文件夹下载的方法及装置。该方法包括:响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据。本申请解决了相关技术中下载文件夹的下载效率低的技术问题。
Description
技术领域
本公开涉及计算机处理领域,具体而言,涉及一种文件夹下载的方法及装置。
背景技术
目前,用户在网络上进行浏览时往往都伴随有下载需求,但是现有技术中对文件进行下载时都只能下载用户特定的一个文件,当用户有多个下载需求时,需要分多次下载才能满足用户的下载需求,这就导致了对文件夹中多个文件进行下载的下载效率低,需要花费用户大量的时间,进而导致用户的使用体验感差。
针对上述的问题,目前尚未提出有效的解决方案。
发明内容
本公开至少部分实施例提供了一种文件夹下载的方法及装置,以至少解决相关技术中下载文件夹的下载效率低的技术问题。
根据本公开其中一实施例,提供了一种文件夹下载的方法,包括:响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据。
根据本公开其中一实施例,还提供了一种文件夹下载的装置,包括:页面显示模块,用于响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;文件获取模块,用于响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;数据下载模块,用于基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据。
根据本公开其中一实施例,还提供了一种计算机可读存储介质,该计算机可读存储介质中存储有计算机程序,其中,计算机程序被设置为运行时执行上述任一项中的文件夹下载的方法。
根据本公开其中一实施例,还提供了一种电子装置,包括存储器和处理器,存储器中存储有计算机程序,处理器被设置为运行计算机程序以执行上述任一项中的文件夹下载的方法。
在本公开至少部分实施例中,采用响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据的方式。容易注意到的是,本公开基于目标种子文件通过网络从资源服务器下载得到的是文件夹,而文件夹中包含至少一个目标文件,可以使用户操作一次就下载完所需的目标文件,达到了能够高效获取多个目标文件的目的,从而实现了提高文件下载效率的技术效果,进而解决了相关技术中下载文件夹的下载效率低的技术问题。
附图说明
此处所说明的附图用来提供对本公开的进一步理解,构成本申请的一部分,本公开的示意性实施例及其说明用于解释本公开,并不构成对本公开的不当限定。在附图中:
图1是根据本公开实施例的一种文件夹下载的方法的移动终端的硬件结构框图;
图2是根据本公开实施例的一种文件夹下载的方法的流程图;
图3是根据本公开实施例的一种可选的浏览器下载器页面的显示示意图;
图4是根据本公开实施例的一种可选的在浏览器的交互界面中显示下载器页面的流程图;
图5是根据本公开实施例的一种可选的下载器页面的第一提示信息示意图;
图6是根据本公开实施例的一种可选的预设种子文件显示示意图;
图7a是根据本公开实施例的一种可选的第一种获取预设种子文件的示意图;
图7b是根据本公开实施例的一种可选的第二种获取预设种子文件的示意图;
图7c是根据本公开实施例的一种可选的第三种获取预设种子文件的示意图;
图8是根据本公开实施例的一种可选的下载器页面的第二提示信息示意图;
图9是根据本公开实施例的一种可选的下载和分享文件夹的流程图;
图10是根据本公开实施例的一种可选的统一建模语言下的流程图;
图11是根据本公开实施例的一种可选的通过资源网站获取文件夹种子的方案示意图;
图12是根据本公开实施例的一种可选的通过访问程序获取文件夹种子的方案示意图;
图13是根据本公开实施例的一种文件夹下载的装置的结构框图;
图14是根据本公开实施例的一种电子装置的示意图。
具体实施方式
为了使本技术领域的人员更好地理解本公开方案,下面将结合本公开实施例中的附图,对本公开实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本公开一部分的实施例,而不是全部的实施例。基于本公开中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本公开保护的范围。
需要说明的是,本公开的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本公开的实施例能够以除了在这里图示或描述的那些以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
为了使本领域技术人员更容易的理解本实施例,下面对本公开中的专有名词进行解释:
网页下载器:本公开所提出一种可以借助浏览器来充当下载器的前端网页文件。
文件夹种子文件:本公开所指代的一个轻量级、基于文本的、可读的格式(JavaScript Object Notation,JSON)文件。里面包括了要下载文件夹的目录信息和文件信息。其中,目录信息包括目录ID,名字,子目录列表。文件信息包括统一资源定位器(Uniform Resource Locator,URL),名字,归属的目录ID。
Github:是一个在线软件源代码托管服务平台。还可以提供免费的静态网站服务器。
Vue:是一个用于创建用户界面的开源视图数据-数据视图(Model-View-ViewModel,MVVM)前端的运行在客户端的脚本语言(JavaScript)框架,也是一个创建单页应用的网页(Web)应用框架。
ElementUI:一套为开发者、设计师和产品经理准备的基于Vue的桌面端组件库。
现有技术中,下载一个文件夹在业界面向用户时,主要有三种办法:1,编写下载程序。例如诸多大型游戏下载前,都会先下载一个下载程序,然后启动下载程序把完整的游戏文件夹下载到本地。2,压缩打包原理。例如用户玩的手游,一般是会在应用/网站点击下载后获取到一个压缩包,打开压缩包即可安装游戏。3,通过文件传输协议(File TransferProtocol,FTP)服务。资源网站开启FTP协议开放访问,用户连接FTP服务器来进行下载资源。
但是现有技术的缺点也很明显:第一种方案操作繁杂而且开发难度大,在开发下载器的过程中也是在开发一个软件,对小需求而言消耗巨大,也会带来维护的困难和系统环境的问题,用户也会觉得下载器很浪费硬盘空间,复用性极差,不同的场景需求需要做到适配并不容易。第二种方案灵活性比较低,多目标分发困难,占用大量额外的空间,只能由分享者决定接收者下载的内容,用户无法根据需求进行定制化下载,打包服务器可以解决定制化下载问题,但也消耗了服务器资源,得不偿失。第三种方案要求下载者要有FTP软件和专业的操作。而且要求资源服务器一定要开启FTP服务,然而网络上很多资源只提供http/https服务的。所以导致前提条件高,应用场景很少。
本公开目的在探究如何让一个或多个文件夹的分享和下载变得简单快捷高效,且容错能力强和复用性强。
在一种可能的实施方式中,针对计算机处理领域下的文件下载背景中通常所采用的文件下载方法,发明人经过实践并仔细研究后,仍然存在下载效率低的技术问题,基于此,本公开实施例应用的下载场景可以是通过浏览器下载,所针对的文件类型一般是文件夹,提出了一种文件夹的下载方法,采用响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据的技术构思,达到了能够高效获取多个目标文件的目的,从而实现了提高文件下载效率的技术效果,进而解决了相关技术中下载文件夹的下载效率低的技术问题。
本公开涉及到的上述方法实施例可以在移动终端、计算机终端或者类似的运算装置中执行。以运行在移动终端上为例,该移动终端可以是智能手机、平板电脑、掌上电脑以及移动互联网设备、PAD、游戏机等终端设备。图1是根据本公开实施例的一种文件夹下载的方法的移动终端的硬件结构框图。如图1所示,移动终端可以包括一个或多个(图1中仅示出一个)处理器102(处理器102可以包括但不限于中央处理器(CPU)、图形处理器(GPU)、数字信号处理(DSP)芯片、微处理器(MCU)、可编程逻辑器件(FPGA)、神经网络处理器(NPU)、张量处理器(TPU)、人工智能(AI)类型处理器等的处理装置)和用于存储数据的存储器104,在本公开其中一实施例中,还可以包括:输入输出设备108以及显示设备110。
本领域技术人员可以理解,图1所示的结构仅为示意,其并不对上述移动终端的结构造成限定。例如,移动终端还可包括比图1中所示更多或者更少的组件,或者具有与图1所示不同的配置。
根据本公开其中一实施例,提供了一种文件夹下载的方法的实施例,需要说明的是,在附图的流程图示出的步骤可以在诸如一组计算机可执行指令的计算机系统中执行,并且,虽然在流程图中示出了逻辑顺序,但是在某些情况下,可以以不同于此处的顺序执行所示出或描述的步骤。
在一种可能的实施方式中,本公开实施例提供了一种文件夹下载的方法。图2是根据本公开实施例的一种文件夹下载的方法的流程图,如图2所示,该方法包括如下步骤:
步骤S202,响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面。
上述的浏览器可以是任意一种能够显示下载器页面的浏览器,在本实施例中不做具体限定。上述的浏览器的交互界面可以是显示在电子设备的显示屏上,方便用户与浏览器进行交互的界面,在本实施例中不做具体限定,此处的电子设备可以包括但不限于:手机、笔记本电脑、平板电脑、个人计算机。
上述的页面打开指令可以是用户在浏览器的交互界面中网址输入框内输入下载器页面的链接地址之后,按压回车按钮所生成的指令,也可以是用户点击本地保存的下载器页面所生成的指令,但不仅限于此。
在一种可选的实施例中,响应于用户对浏览器的下载器页面打开指令,移动终端可以在浏览器的交互界面中显示下载器页面。
在另一种可选的实施例中,响应于用户在浏览器的交互界面中的网址输入框中输入下载器页面的链接地址,并按压回车键,浏览器可以通过网络从资源服务器获取链接地址对应的下载器页面,在获取到下载器页面后浏览器还可以将下载器页面显示在浏览器的交互界面中供用户查看。
在又一种可选的实施例中,响应于用户通过鼠标点击选择保存在本地的浏览器的下载器页面,浏览器可以将下载器页面打开并显示在浏览器的交互界面中。
图3是根据本公开实施例的一种可选的下载器页面的示意图,如图3所示,该下载器页面包括:位于页面上方的“点击选择种子”选项,“选择导出目录”选项,“构建目录”选项,“下载文件”选项以及“结束”选项,用户通过选择不同的选项,浏览器下载器页面会执行相应的操作,同时浏览器下载器页面下方还有时间、大小、下载内容、下载进度的显示区域,当目标种子文件被导入至浏览器的下载器页面后,下载目标种子文件对应的目标文件的进度就会显示在显示区域,包括目标文件的下载时间、大小、下载的内容有哪些以及下载进度到多少等。
可选地,在浏览器的交互界面中显示下载器页面,包括如下之一:通过网络从下载器服务器获取第一下载器页面,并在交互界面中显示第一下载器页面,其中,第一下载器页面用于对第一预设格式的文件数据进行下载;获取本地存储的页面打开指令对应的第二下载器页面,并在交互界面中显示第二下载器页面,其中,第二下载器页面用于对第一预设格式和第二预设格式的文件数据进行下载。
上述的下载器服务器可以是提供下载器页面的服务器,例如,可以是云端服务器,在本实施例中不做具体限定。上述的第一下载器页面可以是通过网络从下载器服务器获取到的下载器页面,用于对第一预设格式的文件数据进行下载。上述的第一预设格式的文件数据可以是通过具有安全性的安全套接字(Secure Socket Layer,SSL)加密传输协议(Hyper Text Transfer Protocol over Secure Socket Layer,即https协议)传输的文件数据。
上述的第二预设格式的文件数据可以是通过超文本传输(Hyper Text TransferProtocol,http)协议和https协议传输的文件数据。上述的第二下载器页面可以是存储在本地的下载器页面,无需通过网络即可以打开第二下载器页面并进行下载任务。
在一种可选的实施例中,响应于接收到用户对浏览器的打开操作,移动终端可以基于页面打开指令通过网络从下载器服务器获取第一下载器页面,并将获取到的第一下载器页面显示在浏览器的交互界面中,其中,第一下载器页面用于对https格式的文件数据进行下载。
在另一种可选的实施例中,通过网络获取到的第一下载器页面只能下载https格式的文件数据,为了同时能够下载http格式的文件数据,可以通过将第一下载器页面存储至本地得到第二下载器页面,并打开第二下载器页面的方式,对http和https格式的文件数据进行下载。需要说明的是,当需要对文件数据进行下载时,实际只需使用一种方案打开下载器页面即可,也即,用户可以根据自身需求选择是通过网络获取第一下载器页面还是直接打开本地存储的第二下载器页面来下载对应的预设格式的文件。
图4是根据本公开实施例的一种可选的在浏览器的交互界面中显示下载器页面的流程图,如图4所示,该方法包括两种方案,方案一为移动终端打开浏览器后,响应于用户在浏览器的输入框中输入下载器页面的链接地址,移动终端可以通过网络从下载器服务器获取到第一下载器页面,并将第一下载器页面显示在浏览器的交互界面中,则第一下载器页面可以通过网络从资源网站中下载目标种子文件对应的目标文件夹,其中,第一下载器页面可以下载https格式的文件数据。需要说明的是,方案一中用户还可以对第一下载器页面进行保存,则第一下载器页面存储至本地后会成为第二下载器页面。
如图4所示,方案二为移动终端打开浏览器后,响应于用户对本地存储的第二下载器页面执行的打开操作,移动终端可以将第二下载器页面显示在浏览器的交互界面中,然后第二下载器页面可以基于网络从资源网站中下载目标种子文件对应的目标文件夹,其中,第二下载器页面可以下载https和http格式的文件数据。
步骤S204,响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息。
上述的目标种子文件可以是用户选择的需要进行下载的文件夹的种子文件,因为是单次下载所以数量为1个。上述的第一描述信息可以是目标文件夹的层次结构信息,例如可以是目标文件夹的目录的树状信息,但不仅限于此。上述的第二描述信息可以是目标文件夹包含的至少一个目标文件的下载信息,例如可以是至少一个目标文件的下载地址、下载名字、下载路径等,但不仅限于此。
在一种可选的实施例中,用户可以提前获取目标种子文件并存储至本地。
在另一种可选的实施例中,响应于用户对浏览器的导入指令,浏览器可以基于导入指令获取对应的目标种子文件,其中,目标种子文件包括:目标文件的第一描述信息和第二描述信息,第一描述信息可以是目标文件夹的层次结构信息,第二描述信息可以是目标文件夹包含的至少一个目标文件的下载信息。
在又一种可选的实施例中,如图3所示,响应于用户选择了“点击选择种子”的选项,浏览器可以基于该选项将对应的目标种子文件导入到浏览器的下载器页面中。
可选地,获取导入指令对应的目标种子文件,包括:在下载器页面中显示至少一个预设种子文件,其中,预设种子文件的组成格式与下载器页面的预设格式相匹配;响应对预设种子文件的第一选择指令,确定第一选择指令对应的预设种子文件为目标种子文件。
可选地,在下载器页面中显示至少一个预设种子文件,包括:在下载器页面中显示第一提示信息,其中,第一提示信息用于提示是否允许浏览器对文件系统执行读取操作,文件系统用于存储预设种子文件;响应对第一提示信息的第一允许指令,在下载器页面中显示至少一个预设种子文件。
上述的预设种子文件可以是预先存储到本地,且与下载器页面的预设格式相匹配的种子文件,需要说明的是,预设种子文件的数据格式是规定不变的,但是保存预设种子文件内容的载体可以是多种文件格式(即预设格式),其中,预设格式可以包括但不限于文本文件(text)格式、超文本标记语言(Hyper Text Mark up Language,HTML)格式。
上述的第一提示信息可以是下载器页面显示的提示是否允许浏览器对文件系统执行读取操作的提示信息,响应于用户选择了是,表明浏览器可以对文件系统执行读取操作,响应于用户选择了否,表明浏览器不可以对文件系统执行读取操作。上述的文件系统可以是本地的用来存储预设种子文件的系统。上述的第一允许指令可以是用户对第一提示信息执行的允许读取指令,响应于用户对第一提示信息执行了第一允许指令,浏览器可以对文件系统执行读取操作,并将预设种子文件显示在下载器页面中。
在一种可选的实施例中,图5是根据本公开实施例的一种可选的下载器页面的第一提示信息示意图,如图5所示,响应于用户选择了“点击选择种子”选项,下载器页面可以显示第一提示信息,如图5中的“是否允许浏览器对文件系统执行读取操作”的提示信息,响应于用户选择了“允许”选项,则浏览器可以对文件系统执行读取操作并将预设种子文件显示在下载器页面中,其中,预设种子文件的组成格式与下载器页面的预设格式相匹配。
上述的第一选择指令可以是用户对预设种子文件的选择指令,响应于用户对预设种子文件执行了第一选择指令,可以确定预设种子文件为目标种子文件。上述的目标种子文件可以是用户选择的需要下载的文件。
在一种可选的实施例中,当至少一个预设种子文件显示在浏览器的下载器页面中后,响应于用户的第一选择指令,可以确定用户选择的预设种子文件为目标种子文件。
图6是根据本公开实施例的一种可选的预设种子文件显示示意图,如图6所示,当用户选择了多个预设种子文件后,可以确定斜线部分的预设种子文件为目标种子文件。
可选地,该方法还包括如下至少之一:通过预设网络接口接收资源服务器发送的预设种子文件;通过网络从群体服务器获取预设种子文件,其中,群体服务器中存储的种子文件来自于资源服务器;利用访问程序对资源服务器进行文件获取,得到预设种子文件;获取预设文件夹包含的至少一个预设文件的下载信息,并对至少一个预设文件的下载信息进行组合,得到预设种子文件。
上述的预设网络接口可以是能够通过网络接收资源服务器发送的预设种子文件的网络接口,该接口由资源服务器的开发人员提供,此处的预设种子文件可以是资源服务器主动提供的用于下载特定文件夹的种子文件。上述的资源服务器可以是为个人用户提供特定文件数据的服务器,例如,可以是资源网站的服务器,但不仅限于此,在本实施例中不做具体限定。
上述的群体服务器可以是为群体用户提供多种文件数据的服务器,例如,可以是社区网站的服务器,在本实施例中不做具体限定。上述的访问程序可以是一种或多种获取网页信息的获取程序,例如可以是通过编程语言(Python)编写得到的程序,但不仅限于此,访问程序可以通过网络对资源服务器进行文件获取以得到预设种子文件。上述的预设文件夹可以是任意一个用户希望下载的文件夹。
在一种可选的实施例中,用户可以通过移动终端的预设网络接口通过网络从资源服务器获取预设种子文件。图7a是根据本公开实施例的一种可选的第一种获取预设种子文件的示意图,如图7a所示,网站开发人员可以提供预设网络接口,资源网站的服务器可以通过预设网络接口将预设种子文件主动发送给移动终端,则移动终端可以获取到预设种子文件。
在另一种可选的实施例中,群体服务器的开发人员可以针对特定的资源服务器研发下载特定文件夹的种子文件,并存储至群体服务器中,能够访问群体服务器的用户可以通过从群体服务器获取预设种子文件。图7b是根据本公开实施例的一种可选的第二种获取预设种子文件的示意图,如图7b所示,社区开发者通过资源网站的服务器输出预设种子文件至社区网站的服务器,则用户可以通过网络从社区网站的服务器获取到预设种子文件。
在另一种可选的实施例中,如图7b所示,首先社区开发者可以通过资源网站的服务器输出特定访问程序至社区网站的服务器,其次用户可以通过网络从社区网站的服务器下载到特定访问程序,然后用户可以通过访问程序对资源网站的服务器进行文件获取,从而可以获取到预设种子文件。
在另一种可选的实施例中,用户可以通过网络对资源服务器中的预设文件中的至少一个预设文件的下载信息进行查找,并对至少一个预设文件的下载信息进行组合,就可以得到预设种子文件。图7c是根据本公开实施例的一种可选的第三种获取预设种子文件的示意图,如图7c所示,用户通过网络对资源网站的服务器进行查找得到至少一个预设文件的下载信息,然后用户通过对至少一个查找到的预设文件的下载信息进行获取和拼凑即可以得到预设种子文件。
在又一种可选的实施例中,如图7c所示,用户可以通过访问程序对资源网站的服务器进行文件获取,进而可以得到预设种子文件。
步骤S206,基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据。
可选地,基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据,包括:对目标种子文件进行解析,得到至少一个目标文件;在下载器页面中显示至少一个目标文件;响应对至少一个目标文件的筛选指令,获取筛选指令对应的筛选文件;通过网络从资源服务器下载筛选文件对应的文件数据。
上述的目标文件可以是目标种子文件中的用户选择要下载的文件,可以为一个,也可以为多个,具体数量在本实施例中不做限定。
上述的筛选指令可以是用户对至少一个目标文件的筛选操作,响应于用户选择了至少一个目标文件,浏览器可以基于选择的筛选文件通过网络从资源服务器下载筛选文件对应的文件数据。
在一种可选的实施例中,浏览器导入目标种子文件后,首先可以对目标种子文件进行解析,得到至少一个目标文件并显示在下载器页面中,其次可以响应于用户对至少一个目标文件的筛选操作,可以确定用户选择的文件即为筛选文件,最后可以通过网络从资源服务器下载筛选文件对应的文件数据。
在另一种可选的实施例中,浏览器导入目标种子文件后,用户还可以对导入的目标种子文件进行挑选,决定剔除或选择哪些目录与文件,从而提高了用户对下载文件的自主选择权,也将重试机制从压缩包级别简化到了文件级别,也即当用户选择错误时,只需重新选择文件即可,不需要重新选择整个文件夹。
可选地,在通过网络从资源服务器下载目标文件夹对应的文件数据的过程中,方法还包括:响应于网络出现故障,保留第一文件对应的文件数据,并暂停下载第二文件对应的文件数据,其中,第一文件对应的文件数据下载成功,第二文件为目标文件夹中除第一文件之外的文件;响应于网络恢复正常,继续下载第二文件对应的文件数据。
上述的第一文件可以是下载成功的文件,第二文件可以是网络出现故障时未下载成功的文件。
在一种可选的实施例中,在通过网络从资源服务器下载目标文件夹对应的文件数据的过程中,响应于网络出现故障,浏览器可以对下载成功的第一文件的文件数据进行保存,并对下载中的第二文件的文件数据进行暂停,以确保文件数据不会丢失,当网络恢复正常后,浏览器可以继续下载第二文件的文件数据,保证了在网络中断过程中文件数据不会丢失并且不需要用户重新执行导入文件的操作,简化了操作步骤。
需要说明的是,本公开的容错机制是文件级别的,即使在整个下载过程中发生了网络错误,也会保留正确下载完的文件到本地。并且在后续重新进行下载过程中,会有断点续传的逻辑,也即当网络出现故障时对第二文件对应的文件数据进行暂停,响应于网络恢复继续下载第二文件对应的文件数据。
可选地,该方法还包括:在下载器页面中显示文件系统中存储的至少一个本地文件;响应对本地文件的第二选择指令,确定第二选择指令对应的本地文件为目标本地文件;基于第一描述信息,在目标本地文件中创建存储文件夹;将目标文件夹对应的文件数据存储至存储文件夹。
上述的第二选择指令可以是浏览器基于用户操作而执行的对本地文件进行选择的指令。上述的目标本地文件可以是用户选择的存储目标文件夹的本地文件,可以是一个也可以是多个,具体数量在本实施例中不做具体限定。
在一种可选的实施例中,当目标文件下载完成后,浏览器的下载器页面还可以显示文件系统中存储的至少一个本地文件,当用户对至少一个本地文件选择后,可以确定选择的至少一个本地文件为目标本地文件。
可选地,基于第一描述信息,在目标本地文件中创建存储文件夹,包括:在下载器页面中显示第二提示信息,其中,第二提示信息用于提示是否允许浏览器对文件系统执行写入操作;响应对第二提示信息的第二允许指令,在目标本地文件中创建存储文件夹。
上述的第二提示信息可以是浏览器响应于用户的选择操作,在下载器页面显示的提示用户是否允许浏览器对文件系统执行写入操作的提示信息,响应于用户选择允许,则浏览器会在目标本地文件中创建存储文件夹以存储下载完成的目标文件。
在一种可选的实施例中,图8是根据本公开实施例的一种可选的下载器页面的第二提示信息示意图,如图8所示,响应于用户选择了“选择导出目录”选项,浏览器的下载器页面会显示“是否允许浏览器对文件系统执行读取操作”的提示信息,响应于用户选择了允许,浏览器会基于第一描述信息在目标本地文件中创建文件夹以存储下载完成的目标文件。
可选地,将目标文件夹对应的文件数据存储至存储文件夹,包括:通过浏览器的预设接口将目标文件夹对应的文件数据存储至存储文件夹。
在一种可选的实施例中,浏览器可以通过预设接口将目标文件夹对应的文件数据存储在目标本地文件中的存储文件夹中。
本公开提供了一种根据网页下载器和文件夹种子文件来下载文件夹的技术,要求文件夹里面的所有文件都是可以通过独立散列的网络连接获取到的。用户通过浏览器打开一个网页,选择特定格式的文件夹种子文件,即可通过网络获取到完整的文件夹内容。只要文件夹种子文件符合下载器的组成格式,就可以复用下载器。种子文件里面存文件的时候,只保存获取文件的URL地址,而不存实质的内容。
本发明的核心内容就是利用一个在线或本地的网页,来实现通用下载器的方案。此网页下载器触发浏览器的文件系统接口,把文件夹内的每一个文件通过网络下载到本地设备。网页下载器具体是通过以下技术方案实现的:
1,浏览器的文件系统(File System)
利用浏览器的文件系统,获取控制系统的权限,通过浏览器提供的原生AJAX接口(fetch)办法建立每个资源的请求,获取网络资源的输入流,然后使用浏览器提供的流式接口把网络请求到的输入流按照流式的办法导入到本地设备。这点非常重要,是原理的介绍和过程的总结。
2,Vue的JavaScript框架
管理网页下载器的所有交互逻辑,正确响应一系列事件,处理数据交互。例如在用户点击页面时有相应的事件反应,可以处理用户筛选文件的事件,进度条能根据发展顺序正确推进,能在网络异常的时候打印出相关信息,这就像一个大脑来执行一个调度和反馈功能的过程。
3,ElementUI的组件使用
负责网页下载器的所有组件样式,美化页面,进度显示和逻辑显示。
4,Github托管静态网站
利用Github免费的静态网站服务,部署我们的下载器,可以让每个人通过一个URL打开和获取到本文的网页下载器,实现在线/本地利用网页下载器的目的。
图9是根据本公开实施例的一种可选的下载和分享文件夹的流程图,如图9所示,该流程包含以下步骤:
1.提前获取一个符合规范格式的文件夹种子文件。里面保存了文件夹的目录的树状信息,文件的下载地址、名字、下载路径以及归属目录编号。
2.用浏览器打开网页下载器,显示下载器页面。
3.导入文件夹种子文件,允许浏览器读取文件系统的权限。
4.选择下载到本地的具体路径,允许浏览器写入文件系统的权限。
5.等待下载完成,查看最终下载结果。
图10是根据本公开实施例的一种可选的统一建模语言(Unified ModelingLanguage,UML)下的流程图,如图10所示,本地设备提前通过某种途径获取到种子文件,然后打开浏览器的网页下载器导入种子文件,浏览器获取本地设备的操作目录的权限后,向本地设备构建目录,同时通过网络从资源服务器下载资源,资源服务器通过预设接口流式返回数据至浏览器的网页下载器,网页下载器对数据进行下载,下载完成后通过目录将文件数据保存至本地。
由于本公开的网页下载器是可以复用的,所以问题只在如何获取文件夹种子文件。
文件夹种子文件有三种获取的途径,如图7a-7c所示:
1.网站开发者提供:最建议推广的办法,资源网站主动提供种子文件。网站开发人员提供文件夹信息访问接口,针对特定的文件夹输出符合下载器格式的种子文件。
2.社区人员获取网站:群体解决问题的办法,群体用户被动寻找种子文件。社区专业技术人员针对特定网站,输出特定访问程序或者种子文件,发布到社区网站上供普通用户下载。
3.普通用户自行组织种子文件:个体解决问题的办法,个体用户被动寻找种子文件。可以手动拼凑,或者借助访问程序整合出对应文件夹的种子文件。
同时,网页下载器还可以部署到Github上,通过链接来打开网页下载器。因为Github还提供静态网站服务,所以部署网页下载器的问题也可以无任何经济支出。因为通过链接打开的网页下载器只能下载支持https协议的资源文件,因此如果想同时下载https和http协议的资源文件,请通过本地文件的形式打开网页下载器。如图4所示。
综上所述,可以针对如下两种场景提出如下的解决方案:
方案一:图11是根据本公开实施例的一种可选的通过资源网站获取文件夹种子的方案示意图,如图11所示,移动终端通过访问资源网站获取或者转发文件夹种子文件,然后将文件夹种子文件到入职浏览器的网页下载器中,网页下载器通过网络从资源网站中下载目标文件,然后将下载完成的目标文件保存至移动终端中。
方案二:图12是根据本公开实施例的一种可选的通过访问程序获取文件夹种子的方案示意图,如图12所示,用户通过访问程序从资源网站中获取得到文件夹种子文件,并将文件夹种子文件导入至浏览器的网页下载器中,网页下载器对获取得到的文件夹种子文件进行下载后,将目标文件存储至移动终端中。
本公开的有益效果如下:
1,本公开只需要编写一个网页,仅依赖浏览器,网页是KB级别的大小,代码简单易懂,还可根据具体需求定制化修改,如加/解密等。
2,本公开提出的网页下载器解开种子文件后,用户可以在网页前端进行二次挑选,决定剔除/选择哪些目录与文件,从而提高了下载用户的自主选择权,也将重试机制从压缩包级别简化到了文件级别。
3,本公开只要种子文件符合网页下载器的格式要求,网页下载器就可以下载这个目录,不针对目录,只针对种子文件的组成格式,因此提高了本方案的普适性和复用性。
4,本公开的网页下载器得到的是一个文件夹,无压缩包概念,不需要加解压操作,也不会占用额外的空间。因为内容源于网络,中转于浏览器,写入到本地设备,没有经过加解压的步骤。
5,本公开的网页下载器可以部署到网站上,用户通过一个链接即可打开下载器,然后导入文件夹种子文件即可开始下载,操作十分简单,可不保存到本地设备。
6,网站开发人员在网站部署网页下载器后,还可以通过重定向的形式把种子文件数据通过网络转发到下载器页面上,进而可以省去用户保存和导入种子文件的烦恼,实现一键下载的目的。通过网络转发时,种子文件的内容就可以通过网络报文载体注入下载器页面。因此,种子文件不是必要手段,只是其中的一个信息载体。
7,本公开的容错机制是文件级别的,即使在整个下载过程中发生了网络错误,也会保留正确下载完的文件到本地。后续重新进行下载过程中,会有断点续传的逻辑。
综上所述,通过网页下载器来下载文件夹,具有速度快,容灾恢复能力强,硬盘空间消耗低,可定制化功能能力强,操作简单,无需额外的硬盘空间,部署方便,直接获取到源文件夹等优点。
需要说明的是,本方案的重点在于:编写了一个网页,此网页经浏览器打开后可以作为下载器下载文件夹,进而解决了相关技术中下载文件夹的技术问题,且该网页下载器拥有高复用高效率以及高容错的特点。此外,该网页下载器可以从资源服务器下载离散的文件资源,其中,离散是指每个文件都有对应的URL,每个URL都保存在信息载体(例如种子文件)中。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到根据上述实施例的方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本公开的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,或者网络设备等)执行本公开各个实施例所述的方法。
在本实施例中还提供了一种装置,该装置用于实现上述实施例及优选实施方式,已经进行过说明的不再赘述。如以下所使用的,术语“单元”、“模块”可以实现预定功能的软件和/或硬件的组合。尽管以下实施例所描述的装置较佳地以软件来实现,但是硬件,或者软件和硬件的组合的实现也是可能并被构想的。
图13是根据本公开实施例的一种文件夹下载的装置的结构框图,如图13所示,该装置包括:页面显示模块1302,用于响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;文件获取模块1304,用于响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;数据下载模块1306,用于基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据。
可选地,文件获取模块包括:页面显示单元,用于在下载器页面中显示至少一个预设种子文件,其中,预设种子文件的组成格式与下载器页面的预设格式相匹配;确定单元,用于响应对预设种子文件的第一选择指令,确定第一选择指令对应的预设种子文件为目标种子文件。
可选地,文件获取模块还包括:发送单元,用于通过预设网络接口接收资源服务器发送的预设种子文件;第一获取单元,用于通过网络从群体服务器获取预设种子文件,其中,群体服务器中存储的种子文件来自于资源服务器;文件获取单元,用于利用访问程序对资源服务器进行文件获取,得到预设种子文件;第二获取单元,用于获取预设文件夹包含的至少一个预设文件的下载信息,并对至少一个预设文件的下载信息进行组合,得到预设种子文件。
可选地,页面显示单元包括:第一显示子单元,用于在下载器页面中显示第一提示信息,其中,第一提示信息用于提示是否允许浏览器对文件系统执行读取操作,文件系统用于存储预设种子文件;第二显示子单元,用于响应对第一提示信息的第一允许指令,在下载器页面中显示至少一个预设种子文件。
可选地,该装置还包括:文件显示模块,用于在下载器页面中显示文件系统中存储的至少一个本地文件;文件确定模块,用于响应对本地文件的第二选择指令,确定第二选择指令对应的本地文件为目标本地文件;文件夹创建模块,用于基于第一描述信息,在目标本地文件中创建存储文件夹;文件数据存储模块,用于将目标文件夹对应的文件数据存储至存储文件夹。
可选地,文件夹创建模块包括:提示信息显示单元,用于在下载器页面中显示第二提示信息,其中,第二提示信息用于提示是否允许浏览器对文件系统执行写入操作;文件夹创建单元,用于响应对第二提示信息的第二允许指令,在目标本地文件中创建存储文件夹。
可选地,文件数据存储模块包括:文件数据存储单元,用于通过浏览器的预设接口将目标文件夹对应的文件数据存储至存储文件夹。
可选地,数据下载模块包括:种子文件解析单元,用于对目标种子文件进行解析,得到至少一个目标文件;文件显示单元,用于在下载器页面中显示至少一个目标文件;第三获取单元,用于响应对至少一个目标文件的筛选指令,获取筛选指令对应的筛选文件;第一下载单元,用于通过网络从资源服务器下载筛选文件对应的文件数据。
可选地,页面显示模块包括如下至少之一:第四获取单元,用于通过网络从下载器服务器获取第一下载器页面,并在交互界面中显示第一下载器页面,其中,第一下载器页面用于对第一预设格式的文件数据进行下载;第五获取单元,用于获取本地存储的页面打开指令对应的第二下载器页面,并在交互界面中显示第二下载器页面,其中,第二下载器页面用于对第一预设格式和第二预设格式的文件数据进行下载。
可选地,数据下载模块还包括:保留单元,用于响应于网络出现故障,保留第一文件对应的文件数据,并暂停下载第二文件对应的文件数据,其中,第一文件对应的文件数据下载成功,第二文件为目标文件夹中除第一文件之外的文件;第二下载单元,用于响应于网络恢复正常,继续下载第二文件对应的文件数据。
需要说明的是,上述各个单元、模块是可以通过软件或硬件来实现的,对于后者,可以通过以下方式实现,但不限于此:上述单元、模块均位于同一处理器中;或者,上述各个单元、模块以任意组合的形式分别位于不同的处理器中。
本公开的实施例还提供了一种计算机可读存储介质,该计算机可读存储介质中存储有计算机程序,其中,该计算机程序被设置为运行时执行上述任一项方法实施例中的步骤。
可选地,在本实施例中,上述计算机可读存储介质可以包括但不限于:U盘、只读存储器(Read-Only Memory,简称为ROM)、随机存取存储器(Random Access Memory,简称为RAM)、移动硬盘、磁碟或者光盘等各种可以存储计算机程序的介质。
可选地,在本实施例中,上述计算机可读存储介质可以位于计算机网络中计算机终端群中的任意一个计算机终端中,或者位于移动终端群中的任意一个移动终端中。
可选地,在本实施例中,上述计算机可读存储介质可以被设置为存储用于执行以下步骤的计算机程序:
步骤S1,响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;
步骤S2,响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;
步骤S3,基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据。
可选地,上述计算机可读存储介质还被设置为存储用于执行以下步骤的程序代码:在下载器页面中显示至少一个预设种子文件,其中,预设种子文件的组成格式与下载器页面的预设格式相匹配;响应对预设种子文件的第一选择指令,确定第一选择指令对应的预设种子文件为目标种子文件。
可选地,上述计算机可读存储介质还被设置为存储用于执行以下步骤的程序代码:通过预设网络接口接收资源服务器发送的预设种子文件;通过网络从群体服务器获取预设种子文件,其中,群体服务器中存储的种子文件来自于资源服务器;利用访问程序对资源服务器进行文件获取,得到预设种子文件;获取预设文件夹包含的至少一个预设文件的下载信息,并对至少一个预设文件的下载信息进行组合,得到预设种子文件。
可选地,上述计算机可读存储介质还被设置为存储用于执行以下步骤的程序代码:在下载器页面中显示第一提示信息,其中,第一提示信息用于提示是否允许浏览器对文件系统执行读取操作,文件系统用于存储预设种子文件;响应对第一提示信息的第一允许指令,在下载器页面中显示至少一个预设种子文件。
可选地,上述计算机可读存储介质还被设置为存储用于执行以下步骤的程序代码:在下载器页面中显示文件系统中存储的至少一个本地文件;响应对本地文件的第二选择指令,确定第二选择指令对应的本地文件为目标本地文件;基于第一描述信息,在目标本地文件中创建存储文件夹;将目标文件夹对应的文件数据存储至存储文件夹。
可选地,上述计算机可读存储介质还被设置为存储用于执行以下步骤的程序代码:在下载器页面中显示第二提示信息,其中,第二提示信息用于提示是否允许浏览器对文件系统执行写入操作;响应对第二提示信息的第二允许指令,在目标本地文件中创建存储文件夹。
可选地,上述计算机可读存储介质还被设置为存储用于执行以下步骤的程序代码:通过浏览器的预设接口将目标文件夹对应的文件数据存储至存储文件夹。
可选地,上述计算机可读存储介质还被设置为存储用于执行以下步骤的程序代码:对目标种子文件进行解析,得到至少一个目标文件;在下载器页面中显示至少一个目标文件;响应对至少一个目标文件的筛选指令,获取筛选指令对应的筛选文件;通过网络从资源服务器下载筛选文件对应的文件数据。
可选地,上述计算机可读存储介质还被设置为存储用于执行以下之一步骤的程序代码:通过网络从下载器服务器获取第一下载器页面,并在交互界面中显示第一下载器页面,其中,第一下载器页面用于对第一预设格式的文件数据进行下载;获取本地存储的页面打开指令对应的第二下载器页面,并在交互界面中显示第二下载器页面,其中,第二下载器页面用于对第一预设格式和第二预设格式的文件数据进行下载。
可选地,上述计算机可读存储介质还被设置为存储用于执行以下之一步骤的程序代码:响应于网络出现故障,保留第一文件对应的文件数据,并暂停下载第二文件对应的文件数据,其中,第一文件对应的文件数据下载成功,第二文件为目标文件夹中除第一文件之外的文件;响应于网络恢复正常,继续下载第二文件对应的文件数据。
在该实施例的计算机可读存储介质中,提供了一种文件夹下载的方法的技术方案。采用响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据的方式。容易注意到的是,本公开基于目标种子文件通过网络从资源服务器下载得到的是文件夹,而文件夹中包含至少一个目标文件,可以使用户操作一次就下载完所需的目标文件,达到了能够高效获取多个目标文件的目的,从而实现了提高文件下载效率的技术效果,进而解决了相关技术中下载文件夹的下载效率低的技术问题。通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本公开实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个计算机可读存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、终端装置、或者网络设备等)执行根据本公开实施方式的方法。
在本申请的示例性实施例中,计算机可读存储介质上存储有能够实现本实施例上述方法的程序产品。在一些可能的实施方式中,本公开实施例的各个方面还可以实现为一种程序产品的形式,其包括程序代码,当所述程序产品在终端设备上运行时,所述程序代码用于使所述终端设备执行本实施例上述“示例性方法”部分中描述的根据本公开各种示例性实施方式的步骤。
根据本公开的实施方式的用于实现上述方法的程序产品,其可以采用便携式紧凑盘只读存储器(CD-ROM)并包括程序代码,并可以在终端设备,例如个人电脑上运行。然而,本公开实施例的程序产品不限于此,在本公开实施例中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
上述程序产品可以采用一个或多个计算机可读介质的任意组合。该计算机可读存储介质例如可以为但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列举)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。
需要说明的是,计算机可读存储介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、有线、光缆、RF等等,或者上述的任意合适的组合。
本公开的实施例还提供了一种电子装置,包括存储器和处理器,该存储器中存储有计算机程序,该处理器被设置为运行计算机程序以执行上述任一项方法实施例中的步骤。
可选地,上述电子装置还可以包括传输设备以及输入输出设备,其中,该传输设备和上述处理器连接,该输入输出设备和上述处理器连接。
可选地,在本实施例中,上述处理器可以被设置为通过计算机程序执行以下步骤:
步骤S1,响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;
步骤S2,响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;
步骤S3,基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据。
可选地,上述处理器还可以被设置为通过计算机程序执行以下步骤:在下载器页面中显示至少一个预设种子文件,其中,预设种子文件的组成格式与下载器页面的预设格式相匹配;响应对预设种子文件的第一选择指令,确定第一选择指令对应的预设种子文件为目标种子文件。
可选地,上述处理器还可以被设置为通过计算机程序执行以下步骤:通过预设网络接口接收资源服务器发送的预设种子文件;通过网络从群体服务器获取预设种子文件,其中,群体服务器中存储的种子文件来自于资源服务器;利用访问程序对资源服务器进行文件获取,得到预设种子文件;获取预设文件夹包含的至少一个预设文件的下载信息,并对至少一个预设文件的下载信息进行组合,得到预设种子文件。
可选地,上述处理器还可以被设置为通过计算机程序执行以下步骤:在下载器页面中显示第一提示信息,其中,第一提示信息用于提示是否允许浏览器对文件系统执行读取操作,文件系统用于存储预设种子文件;响应对第一提示信息的第一允许指令,在下载器页面中显示至少一个预设种子文件。
可选地,上述处理器还可以被设置为通过计算机程序执行以下步骤:在下载器页面中显示文件系统中存储的至少一个本地文件;响应对本地文件的第二选择指令,确定第二选择指令对应的本地文件为目标本地文件;基于第一描述信息,在目标本地文件中创建存储文件夹;将目标文件夹对应的文件数据存储至存储文件夹。
可选地,上述处理器还可以被设置为通过计算机程序执行以下步骤:在下载器页面中显示第二提示信息,其中,第二提示信息用于提示是否允许浏览器对文件系统执行写入操作;响应对第二提示信息的第二允许指令,在目标本地文件中创建存储文件夹。
可选地,上述处理器还可以被设置为通过计算机程序执行以下步骤:通过浏览器的预设接口将目标文件夹对应的文件数据存储至存储文件夹。
可选地,上述处理器还可以被设置为通过计算机程序执行以下步骤:对目标种子文件进行解析,得到至少一个目标文件;在下载器页面中显示至少一个目标文件;响应对至少一个目标文件的筛选指令,获取筛选指令对应的筛选文件;通过网络从资源服务器下载筛选文件对应的文件数据。
可选地,上述处理器还可以被设置为通过计算机程序执行以下步骤:通过网络从下载器服务器获取第一下载器页面,并在交互界面中显示第一下载器页面,其中,第一下载器页面用于对第一预设格式的文件数据进行下载;获取本地存储的页面打开指令对应的第二下载器页面,并在交互界面中显示第二下载器页面,其中,第二下载器页面用于对第一预设格式和第二预设格式的文件数据进行下载。
可选地,上述处理器还可以被设置为通过计算机程序执行以下步骤:响应于网络出现故障,保留第一文件对应的文件数据,并暂停下载第二文件对应的文件数据,其中,第一文件对应的文件数据下载成功,第二文件为目标文件夹中除第一文件之外的文件;响应于网络恢复正常,继续下载第二文件对应的文件数据。
在该实施例的电子装置中,提供了一种文件夹下载的方法的技术方案。采用响应对浏览器的页面打开指令,在浏览器的交互界面中显示下载器页面;响应对下载器页面的导入指令,获取导入指令对应的目标种子文件,其中,目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,第一描述信息为目标文件夹的层次结构信息,第二描述信息为目标文件夹包含的至少一个目标文件的下载信息;基于目标种子文件,通过网络从资源服务器下载目标文件夹对应的文件数据的方式。容易注意到的是,本公开基于目标种子文件通过网络从资源服务器下载得到的是文件夹,而文件夹中包含至少一个目标文件,可以使用户操作一次就下载完所需的目标文件,达到了能够高效获取多个目标文件的目的,从而实现了提高文件下载效率的技术效果,进而解决了相关技术中下载文件夹的下载效率低的技术问题。
图14是根据本公开实施例的一种电子装置的示意图。如图14所示,电子装置1400仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图14所示,电子装置1400以通用计算设备的形式表现。电子装置1400的组件可以包括但不限于:上述至少一个处理器1410、上述至少一个存储器1420、连接不同系统组件(包括存储器1420和处理器1410)的总线1430和显示器1440。
其中,上述存储器1420存储有程序代码,所述程序代码可以被处理器1410执行,使得处理器1410执行本申请实施例的上述方法部分中描述的根据本公开各种示例性实施方式的步骤。
存储器1420可以包括易失性存储单元形式的可读介质,例如随机存取存储单元(RAM)14201和/或高速缓存存储单元14202,还可以进一步包括只读存储单元(ROM)14203,还可包括非易失性存储器,如一个或者多个磁性存储装置、闪存、或者其他非易失性固态存储器。
在一些实例中,存储器1420还可以包括具有一组(至少一个)程序模块14205的程序/实用工具14204,这样的程序模块14205包括但不限于:操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。存储器1420可进一步包括相对于处理器1410远程设置的存储器,这些远程存储器可以通过网络连接至电子装置1400。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
总线1430可以为表示几类总线结构中的一种或多种,包括存储单元总线或者存储单元控制器、外围总线、图形加速端口、处理器1410或者使用多种总线结构中的任意总线结构的局域总线。
显示器1440可以例如触摸屏式的液晶显示器(LCD),该液晶显示器可使得用户能够与电子装置1400的用户界面进行交互。
可选地,电子装置1400也可以与一个或多个外部设备1500(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与该电子装置1400交互的设备通信,和/或与使得该电子装置1400能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口1450进行。并且,电子装置1400还可以通过网络适配器1460与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图14所示,网络适配器1460通过总线1430与电子装置1400的其它模块通信。应当明白,尽管图14中未示出,可以结合电子装置1400使用其它硬件和/或软件模块,可以包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
上述电子装置1400还可以包括:键盘、光标控制设备(如鼠标)、输入/输出接口(I/O接口)、网络接口、电源和/或相机。
本领域普通技术人员可以理解,图14所示的结构仅为示意,其并不对上述电子装置的结构造成限定。例如,电子装置1400还可包括比图14中所示更多或者更少的组件,或者具有与图1所示不同的配置。存储器1420可用于存储计算机程序及对应的数据,如本公开实施例中文件夹下载的方法对应的计算机程序及对应的数据。处理器1410通过运行存储在存储器1420内的计算机程序,从而执行各种功能应用以及数据处理,即实现上述的文件夹下载方法。
上述本公开实施例序号仅仅为了描述,不代表实施例的优劣。
在本公开的上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述的部分,可以参见其他实施例的相关描述。
在本申请所提供的几个实施例中,应该理解到,所揭露的技术内容,可通过其它的方式实现。其中,以上所描述的装置实施例仅仅是示意性的,例如所述单元的划分,可以为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,单元或模块的间接耦合或通信连接,可以是电性或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本公开各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本公开的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可为个人计算机、服务器或者网络设备等)执行本公开各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、移动硬盘、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述仅是本公开的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本公开原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视为本公开的保护范围。
Claims (13)
1.一种文件夹下载的方法,其特征在于,包括:
响应对浏览器的页面打开指令,在所述浏览器的交互界面中显示下载器页面;
响应对所述下载器页面的导入指令,获取所述导入指令对应的目标种子文件,其中,所述目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,所述第一描述信息为所述目标文件夹的层次结构信息,所述第二描述信息为所述目标文件夹包含的至少一个目标文件的下载信息;
基于所述目标种子文件,通过网络从资源服务器下载所述目标文件夹对应的文件数据。
2.根据权利要求1所述的方法,其特征在于,获取所述导入指令对应的所述目标种子文件,包括:
在所述下载器页面中显示至少一个预设种子文件,其中,所述预设种子文件的组成格式与所述下载器页面的预设格式相匹配;
响应对所述预设种子文件的第一选择指令,确定所述第一选择指令对应的预设种子文件为所述目标种子文件。
3.根据权利要求2所述的方法,其特征在于,所述方法还包括如下至少之一:
通过预设网络接口接收所述资源服务器发送的所述预设种子文件;
通过所述网络从群体服务器获取所述预设种子文件,其中,所述群体服务器中存储的种子文件来自于所述资源服务器;
利用访问程序对所述资源服务器进行文件获取,得到所述预设种子文件;
获取预设文件夹包含的至少一个预设文件的下载信息,并对所述至少一个预设文件的下载信息进行组合,得到所述预设种子文件。
4.根据权利要求2所述的方法,其特征在于,在所述下载器页面中显示所述至少一个预设种子文件,包括:
在所述下载器页面中显示第一提示信息,其中,所述第一提示信息用于提示是否允许所述浏览器对文件系统执行读取操作,所述文件系统用于存储所述预设种子文件;
响应对所述第一提示信息的第一允许指令,在所述下载器页面中显示所述至少一个预设种子文件。
5.根据权利要求1所述的方法,其特征在于,所述方法还包括:
在所述下载器页面中显示文件系统中存储的至少一个本地文件;
响应对所述本地文件的第二选择指令,确定所述第二选择指令对应的本地文件为目标本地文件;
基于所述第一描述信息,在所述目标本地文件中创建存储文件夹;
将所述目标文件夹对应的文件数据存储至所述存储文件夹。
6.根据权利要求5所述的方法,其特征在于,基于所述第一描述信息,在所述目标本地文件中创建所述存储文件夹,包括:
在所述下载器页面中显示第二提示信息,其中,所述第二提示信息用于提示是否允许所述浏览器对所述文件系统执行写入操作;
响应对所述第二提示信息的第二允许指令,在所述目标本地文件中创建所述存储文件夹。
7.根据权利要求5所述的方法,其特征在于,将所述目标文件夹对应的文件数据存储至所述存储文件夹,包括:
通过所述浏览器的预设接口将所述目标文件夹对应的文件数据存储至所述存储文件夹。
8.根据权利要求1所述的方法,其特征在于,基于所述目标种子文件,通过所述网络从所述资源服务器下载所述目标文件夹对应的文件数据,包括:
对所述目标种子文件进行解析,得到所述至少一个目标文件;
在所述下载器页面中显示所述至少一个目标文件;
响应对所述至少一个目标文件的筛选指令,获取所述筛选指令对应的筛选文件;
通过所述网络从所述资源服务器下载所述筛选文件对应的文件数据。
9.根据权利要求1所述的方法,其特征在于,在所述浏览器的所述交互界面中显示所述下载器页面,包括如下之一:
通过所述网络从下载器服务器获取第一下载器页面,并在所述交互界面中显示所述第一下载器页面,其中,所述第一下载器页面用于对第一预设格式的文件数据进行下载;
获取本地存储的所述页面打开指令对应的第二下载器页面,并在所述交互界面中显示所述第二下载器页面,其中,所述第二下载器页面用于对第一预设格式和第二预设格式的文件数据进行下载。
10.根据权利要求1所述的方法,其特征在于,在通过所述网络从所述资源服务器下载所述目标文件夹对应的文件数据的过程中,所述方法还包括:
响应于所述网络出现故障,保留第一文件对应的文件数据,并暂停下载第二文件对应的文件数据,其中,所述第一文件对应的文件数据下载成功,所述第二文件为所述目标文件夹中除所述第一文件之外的文件;
响应于所述网络恢复正常,继续下载所述第二文件对应的文件数据。
11.一种文件夹下载的装置,其特征在于,包括:
页面显示模块,用于响应对浏览器的页面打开指令,在所述浏览器的交互界面中显示下载器页面;
文件获取模块,用于响应对所述下载器页面的导入指令,获取所述导入指令对应的目标种子文件,其中,所述目标种子文件包括:目标文件夹的第一描述信息和第二描述信息,所述第一描述信息为所述目标文件夹的层次结构信息,所述第二描述信息为所述目标文件夹包含的至少一个目标文件的下载信息;
数据下载模块,用于基于所述目标种子文件,通过网络从资源服务器下载所述目标文件夹对应的文件数据。
12.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质中存储有计算机程序,其中,所述计算机程序被设置为被处理器运行时执行权利要求1至10任一项中所述的方法。
13.一种电子装置,包括存储器和处理器,其特征在于,所述存储器中存储有计算机程序,所述处理器被设置为运行所述计算机程序以执行权利要求1至10任一项中所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211536863.1A CN116016485A (zh) | 2022-12-02 | 2022-12-02 | 文件夹下载的方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211536863.1A CN116016485A (zh) | 2022-12-02 | 2022-12-02 | 文件夹下载的方法及装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN116016485A true CN116016485A (zh) | 2023-04-25 |
Family
ID=86036176
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211536863.1A Pending CN116016485A (zh) | 2022-12-02 | 2022-12-02 | 文件夹下载的方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN116016485A (zh) |
-
2022
- 2022-12-02 CN CN202211536863.1A patent/CN116016485A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6774499B2 (ja) | オフラインでのハイブリッドアプリケーションへのアクセスの提供 | |
Kalin | Java Web Services | |
KR102220127B1 (ko) | 커스터마이징된 소프트웨어 개발 키트(sdk) 생성을 위한 방법 및 장치 | |
Kurniawan | Learning AWS IoT: Effectively manage connected devices on the AWS cloud using services such as AWS Greengrass, AWS button, predictive analytics and machine learning | |
Sciabarrà | LEARNING APACHE OPENWHISK: developing open serverless solutions | |
Hall | Ansible configuration management | |
US8990266B2 (en) | Dynamic data transformations for network transmissions | |
Moyer | Building Applications in the Cloud: Concepts, Patterns, and Projects | |
Hanjura | Heroku cloud application development | |
Ihrig et al. | Full Stack JavaScript Development With MEAN: MongoDB, Express, AngularJS, and Node. JS | |
Rakowski | Learning Apache Thrift | |
Sanderson | Programming Google App Engine with Python: Build and Run Scalable Python Apps on Google's Infrastructure | |
Bojinov | RESTful Web API Design with Node. js 10: Learn to create robust RESTful web services with Node. js, MongoDB, and Express. js | |
WO2023092580A1 (zh) | 页面显示方法、装置、存储介质及电子设备 | |
Kessin | Building Web Applications with Erlang: Working with REST and Web Sockets on Yaws | |
Hane | Build your own PaaS with Docker | |
Bojinov | RESTful Web API Design with Node. js | |
CN116016485A (zh) | 文件夹下载的方法及装置 | |
Kholodkov | Nginx Essentials | |
Prusty | Modern JavaScript Applications | |
Klems | AWS Lambda Quick Start Guide: Learn how to build and deploy serverless applications on AWS | |
Tsonev | Node. js by example | |
Dawson et al. | Building tools with GitHub: customize your workflow | |
Juell | From containers to Kubernetes with Node. js | |
Pippi | Python for Google App Engine |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |