教你突破基于HTTP_REFERER的防盗链的方法

2022-12-13服务器
267

其实防盗链这个技术并不复杂,目前基本就是在服务器端判断HTTP_REFERER的位置,如果不是来自本站自身,则拒绝输出详细。
那么如果考虑突破防盗链的措施,就需要考虑在HTTPREFERER上面做手脚了。PHP 脚本中对应的变量是$SERVER['HTTPREFERER'] ,它存储了 HTTPREFERER 的值。
由于直接访问目标URL资源已经被上述防盗链的措施给屏蔽,所以我们需要个类似网关的玩意去获取。说白了就是编写已经包装过的HTTP头的 PHP 脚本。
下面是简单的函数实现:
function getRemoteFile($url, $refer = '') { 
    $option = array( 
            'http' => array( 
                'header' => "Referer:$refer") 
            ); 
    $context = stream_context_create($option); 
    return file_get_contents($url, false, $context); 
} 
这是个比较简单的函数,其功能就是伪造 Referer (使用 streamcontextcreate 函数 )然后获取对方的数据(使用 filegetcontents,需要开启 allowurlfopen )。
如果想「复杂」一点,可以使用 sockets 扩展 ,这不在这里的讨论范围以内。
另外,再提供个获取主机名的正则函数
function getHost($url) { 
    $result = preg_match('/^http://([d|w|.]+)//', $url, $matches); 
    if (sizeof($matches) >= 2)  { 
        return $matches[1]; 
    } else { 
        return null; 
    } 
} 
再进一步的扩展,可以封装成脚本,然后譬如调用
http://127.0.0.1/proxy.php?url=http://i.am/img 
就可以获取那些开启防盗链措施的链接了。
The End
防盗链

相关推荐

教你突破基于HTTP_REFERER的防盗链的方法
其实防盗链这个技术并不复杂,目前基本就是在服务器端判断HTTP_REFERER的位置,如果不是来自本站自身,则拒绝输出详细。 那么如果考虑突破防盗链的措施,就需要考虑在HTTPREFERER上面做手脚了。PHP 脚本中对应的变量是$SERVER[HTTPREFERER] ,它存储了 HTTPRE...
2022-12-13 服务器
267

Apache 防盗链的技术小结
Apache 防盗链的第一种实现方法,可以用 rewrite 实现。...
2016-09-25 服务器
10

Nginx防盗链的3种方法
Nginx防盗链的3种方法,需要的朋友可以参考下。...
2016-09-25 服务器
5

LiteSpeed服务器用htaccess的防盗链代码
最近换到hawkhost,他们用的是LiteSpeed Webserver作为HTTP服务器软件,而不是Apache,以前使用的htaccess在这里不生效。...
2016-09-25 服务器
4

Apache下MP3 防盗链的解决办法
对于很多放MP3的网站来说,防盗链对于控制流量是个非常重要的事情,尤其是MP3被百度收录之后,那流量大的惊人,每天都上百G的流量,很快你的站点的流量就会用光了。...
2016-09-25 服务器
8

真正可用的IIS的ISAPI-Rewrite伪静态URL图片防盗链规则写法
本规则支持白名单排除式防盗链,搜索引擎友好不屏蔽,被盗链后的错误提示转向,支持各种文件类型,经作者亲验真的能用...
2016-09-25 服务器
9