输入是可变数量的 URL(远程),所有链接图像资源。希望允许用户允许批量下载所有这些 URL。由于我们谈论的是 1000-2000 个图像资源,因此要求用户为每个 URL 单击“另存为...”是不可行的。
我最初的尝试是将所有图像下载到一个 blob 中(如何将加载的图像读入 blob?,由于同源策略而不起作用),归档文件并允许用户下载它(所有这个客户端边)。
我想知道有哪些可能的替代解决方案?无论解决方案是什么,都不得涉及随时将远程资源下载到服务器。
输入是可变数量的 URL(远程),所有链接图像资源。希望允许用户允许批量下载所有这些 URL。由于我们谈论的是 1000-2000 个图像资源,因此要求用户为每个 URL 单击“另存为...”是不可行的。
我最初的尝试是将所有图像下载到一个 blob 中(如何将加载的图像读入 blob?,由于同源策略而不起作用),归档文件并允许用户下载它(所有这个客户端边)。
我想知道有哪些可能的替代解决方案?无论解决方案是什么,都不得涉及随时将远程资源下载到服务器。
虽然这不可能,但我设法在 Chrome 中用一些魔法做到了这一点。首先,您需要为download
所有链接 f.ex 设置属性:
<a href="http://example.com/image1.jpg" download>download</a>
<a href="http://example.com/image2.jpg" download>download</a>
然后创建一个合成点击函数:
function makeClick(element) {
var evt = element.ownerDocument.createEvent('MouseEvents');
evt.initMouseEvent('click', true, true,
element.ownerDocument.defaultView, 1, 0, 0, 0, 0, false,
false, false, false, 1, null);
element.dispatchEvent(evt);
}
然后只需遍历您的链接并调用它:
var links = document.getElementsByTagName('a');
for(var i=0;i<links.length; i++) {
makeClick(links[i]);
}
这是一个演示:http: //jsfiddle.net/37pFC/
在 Chrome 中,您会收到类似“此站点希望您下载多个文件。允许?”的警告。但这可能是可以管理的。
免责声明:我没有在其他浏览器中尝试过,我认为它不是非常友好的跨浏览器。
我真的想不出更好的办法,只能根据用户的偏好在服务器端准备一个存档,然后让用户下载包。
我猜你可以让用户安装一个浏览器扩展,允许对二进制数据和本地文件系统进行更多控制,但我怀疑这就是你要找的。