下载文件时的浏览器事件保存到磁盘

时间:2010-02-26 17:13:23

标签: javascript browser download save dom-events

我有敏感文件要下载给用户,每个用户只允许下载一次给定文件。如果下载失败,我想允许重新下载,但不允许。

依靠在服务器上记录/处理文件下载请求是不够的 - 我需要确定地知道文件何时完成并在客户端就位,因为我的许多用户都在工作在频繁连接下降的环境中。

最简单的方法是,如果浏览器从“另存为...”对话框中显示“文件已保存”事件,该对话框可以连接到下载页面上的JavaScript函数(可以回发到服务器)。但是,直觉表明,如果浏览器暴露了这个功能,可能会出现安全漏洞,因为它会在沙箱之外偷偷溜走。我不确定这是否可能。

found several other questions in this area,但没有具体针对此问题。

有什么想法吗?

编辑:我不应该在原始问题中使用“安全”一词,抱歉引发红色鲱鱼。

编辑2:我的“安全”措辞误导人们进入了非正式的技术安全问题,但你们两人都证实了我的怀疑,“不,没有浏览器支持。”因为他的第一句话得到了我的期待,所以我正在为第一个评论者做出回答。谢谢大家。

3 个答案:

答案 0 :(得分:18)

这是一个很好的解决方案:

http://gruffcode.com/2010/10/28/detecting-the-file-download-dialog-in-the-browser/

它基本上可以通过在下载文件的响应标头中设置cookie来工作,因此javascript会定期检查此cookie的存在...

答案 1 :(得分:9)

JavaScript中没有此类浏览器事件,即使您无法信任用户的浏览器为您提供安全保障。

最好使用GUID为每次下载生成唯一的URL。然后,您可以例如:

  • 让网址仅在特定时间段内有效
  • 仅允许从与唯一网址相关联的特定IP地址进行转移
  • 让您的服务器端代码检测何时完全转移了唯一网址的内容,然后使该网址无效。

让我澄清最后一颗子弹。假设您正在使用Java - 您将在循环中in.read(buffer)out.write(buffer)直到EOF。如果客户端断开连接,您将在IOException期间收到out.write(),并且能够从中断的客户端成功下载。在其他平台上,我确信有办法判断连接是否丢失。

编辑:您实际上可以使用one of the questions you linked to中接受的答案中列出的技巧触发浏览器事件。然而,这不是限制下载次数的可靠解决方案。

答案 2 :(得分:1)

为什么文件可以“一次”下载很重要?文件下载后可以复制,因此让同一用户多次下载文件确实存在安全问题吗?

如果没有,你可以这样做:

  1. 生成唯一的URL以下载给定文件。 (必要时使用GUID来提供障碍)
  2. 将该URL与USER INFO(浏览器类型,IP地址等)和A TIME WINDOW相关联。仅允许该用户和窗口期间的下载。
  3. 窗口应该足够长,以便用户注意到传输失败并重新尝试一次或两次,但不再重复。
  4. 最终结果是:

    1. 您可以合理地确定该文件仅由目标收件人下载。
    2. 您可以确定收件人只能在短时间内下载文件。
    3. 同一个用户可以多次下载该文件,但谁在乎呢?这与制作第一个文件的本地副本没什么不同。
    4. 如果您真的很担心,请记录每个下载请求并为多次下载的文件运行预定报告。如果看起来有些可疑,你可以检查安全日志,与用户交谈等等。