分类:
2008-05-29 10:15:51
我用的apache 2, php 4.3 有下面一段请求:
这样一段请求,注意: bytes=19434798- 而我的download.php只有10000字节大,里面的代码作了这样的工作: 根据客户url传来的内容和http头中传来的开始位置,在服务器端循环读取相应的文件,并且echo到客户端。目的是彻底实现“防盗链”,并实现下载计数。因为单纯redirect到真实url根本起不到防盗作用。 但是只要request的Range字段指定的起始下载位置比download.php自身的大小还要大,根本就没有来得及起动php解析器解析并执行download.php,直接在apache层就给回绝了。 问题: 1、有没有办法得到http请求头的range字段?如果有的话,我不知道是否能够避免apache直接就回绝range“不合理”的请求。 2、如果我这样的想法不可以实现,实现作防盗链并且能够支持多线程下载的办法是什么? 谢谢! ---------------------------------------------------------------
--------------------------------------------------------------- 这篇文章。 针对网页上做防盗链没什么好办法。 最好是在服务器端加强。 --------------------------------------------------------------- 我试过还不错 //以下内容为程序代码:
这样可以通过判断HTTP_REFERER或者用会员认证的方式来提供下载,因为永远看不到真实路径。不过缺点是影响性能,而且似乎不支持续传(未验证)。实际演示在,点开一个midi后,里面会出现下载地址,而你无论用什么方法,都看不到实际地址。(本例中文件存储在数据库中,实际使用时候你可以不这么做,readfile就行) |