询问类似 fileserve.com 的防盗链原理

2010-09-04 00:50:54 +08:00
 WinG
http://www.fileserve.com/file/tSm8Uqe

http://fs312v2d05.fileserve.com/dl/e8222973f4d9025ee46347e9e3f0bfa0/4c81257f/f969c2/DirectAdmin.zip

http://fs312v2d05.fileserve.com/dl/947dc9425dcef58feff273299077762d/4c812686/f969c2/DirectAdmin.zip

下载一次地址变一次~~
6953 次点击
所在节点    服务器
14 条回复
zaykl
2010-09-04 01:01:58 +08:00
刚好某日自己也考虑过这个问题,不过是想到的点也不是很ok,大致是创建一个临时表,然后key与文件对应.后台有个程序每过一段时间把这记录给清除掉...


比较笨的想法.
WinG
2010-09-04 01:20:33 +08:00
他这个几乎是立刻改变地址的
GordianZ
2010-09-04 02:15:54 +08:00
@WinG 应该就是@zaykl 的办法,加了个时间的HASH
request之后按照request的时间(和其它的信息)HASH出一个KEY,然后生成地址,dispatcher一接收到访问可以立即删除/flag这个key,保证不被重用
gonbo
2010-09-04 11:43:20 +08:00
这个防盗链,需要一个防盗链的key
WinG
2010-09-04 15:52:46 +08:00
@GordianZ 还是没懂 那不文件目录也改变了??..
WinG
2010-09-04 16:06:10 +08:00
@GordianZ 不是真实地址那会不会探测到真实地址?
GordianZ
2010-09-04 16:39:53 +08:00
@WinG 这种专门的下载站会写一个模块来buffer文件然后输出,并不是静态访问,所以不存在真实地址,每次下载所返回的资源都只在当前session有效。
WinG
2010-09-04 16:56:56 +08:00
@GordianZ 能通俗点详解流程吗。。谢谢哈..!!
WinG
2010-09-04 17:10:26 +08:00
方法6:使用动态文件名

也叫动态钥匙法,当用户点击一个下载链接时,先在程序端计算一个Key(使用一定规律产生的Key,最好不要使用随机字符串例如GUID,并且这个 Key必须有一定时效的),然后在数据库或Cache里记录这个Key以及它所对应的资源ID或文件名,最后让网页重定向一个新的URL地址,这个新 URL地址里需要包含这个Key。当浏览器或下载工具发出下载请求时,程序先检测这个Key是否存在,如果存在则返回对应的资源数据。
使用这个方法的好处是下载工具也可以下载,并且在Key失效前可以断点续传,并且可以通过Key来控制下载的线程数。

使用这个方法(包括以上所有支持下载工具的方法)的缺点是:当任意一个用户下载成功之后,你的资源就会被一些下载工具列入“资源候选名单”,以后其他人在其他地方下载同样的文件时,下载工具会不断连接你的服务器,即使你的文件已经删除或者Key已经失效了,这样会造成类DDos攻击的后果,下面再介绍两个即可以让下载工具下载,又可以防止盗链的方法。
WinG
2010-09-04 17:10:59 +08:00
@GordianZ 下载工具会不断连接你的服务器,即使你的文件已经删除或者Key已经失效了,这样会造成类DDos攻击的后果,下面再介绍两个即可以让下载工具下载,又可以防止盗链的方法。

会吗???
GordianZ
2010-09-04 17:35:09 +08:00
@WinG 让下载工具下载并且防盗链是不现实的,现在的下载工具可以仿UA/引用页/cookie,你看看QQ中转站的盗链就知道了。如果想防盗链必须用单个session且不能续传的方法,在国内也不是很现实……
CupTools
2010-09-06 01:38:37 +08:00
将用户的UA和IP hash了,这不就行了
muxi
2010-09-06 10:46:21 +08:00
原理很简单,就是根据一些条件做个一段时间内有效的可逆hash,参见
http://wiki.nginx.org/NginxHttpAccessKeyModule
WinG
2010-09-07 23:16:43 +08:00
@GordianZ @CupTools @muxi 谢谢谢

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/2275

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX