WinG
V2EX  ›  服务器

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

  •  
  •   WinG · Sep 4, 2010 · 7583 views
    This topic created in 5758 days ago, the information mentioned may be changed or developed.
    14 replies    1970-01-01 08:00:00 +08:00
    zaykl
        1
    zaykl  
       Sep 4, 2010
    刚好某日自己也考虑过这个问题,不过是想到的点也不是很ok,大致是创建一个临时表,然后key与文件对应.后台有个程序每过一段时间把这记录给清除掉...


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

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

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

    会吗???
    GordianZ
        11
    GordianZ  
       Sep 4, 2010
    @WinG 让下载工具下载并且防盗链是不现实的,现在的下载工具可以仿UA/引用页/cookie,你看看QQ中转站的盗链就知道了。如果想防盗链必须用单个session且不能续传的方法,在国内也不是很现实……
    CupTools
        12
    CupTools  
       Sep 6, 2010
    将用户的UA和IP hash了,这不就行了
    muxi
        13
    muxi  
       Sep 6, 2010
    原理很简单,就是根据一些条件做个一段时间内有效的可逆hash,参见
    http://wiki.nginx.org/NginxHttpAccessKeyModule
    WinG
        14
    WinG  
    OP
       Sep 7, 2010
    @GordianZ @CupTools @muxi 谢谢谢
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1314 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 35ms · UTC 23:48 · PVG 07:48 · LAX 16:48 · JFK 19:48
    ♥ Do have faith in what you're doing.