php中突破基于HTTP_REFERER的防盗链措施(stream_context_create)
作者:bea
那么如果考虑突破防盗链的措施,就需要考虑在 HTTP_REFERER 上面做手脚了。PHP 脚本中对应的变量是 $_SERVER['HTTP_REFERER'] ,它存储了 HTTP_REFERER 的值。 由于直接访问目标 URL 资源已经被上述防盗链的措施给屏蔽,所以我们需要个类似网关的玩意去获取。说白了就是编写已经包装过的 HTTP 头的 PHP 脚本。 下面是简单的函数实现: 代码如下: function getRemoteFile($url, $refer =
那么如果考虑突破防盗链的措施,就需要考虑在 HTTP_REFERER 上面做手脚了。PHP 脚本中对应的变量是 $_SERVER['HTTP_REFERER'] ,它存储了 HTTP_REFERER 的值。
由于直接访问目标 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 (使用 stream_context_create 函数)然后获取对方的数据(使用 file_get_contents,需要开启 allow_url_fopen )。
如果想“复杂”一点,可以使用 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就可以获取那些开启防盗链措施的链接了(再发挥下,使用 Javascript 将图片链接全部替换)。
有用 | 无用
由于直接访问目标 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 (使用 stream_context_create 函数)然后获取对方的数据(使用 file_get_contents,需要开启 allow_url_fopen )。
如果想“复杂”一点,可以使用 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就可以获取那些开启防盗链措施的链接了(再发挥下,使用 Javascript 将图片链接全部替换)。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- PHP学习之字符串比较和查找
- PHP学习之整理字符串
- PHP学习之输出字符串(echo,print,printf,print_r和var_dump)
- php 生成文字png图片的代码
- 适用于php-5.2 的 php.ini 中文版[金步国翻译]
- php编写一个简单的路由类
- php 求质素(素数) 的实现代码
- php 5.3.5安装memcache注意事项小结
- php处理json时中文问题的解决方法
- php 面向对象的一个例子
- 深入理解PHP原理之Session Gc的一个小概率Notice
- php表单提交问题的解决方法
- 使用NetBeans + Xdebug调试PHP程序的方法
- php产生随机数的两种方法实例代码 输出随机IP
- PHP随机数生成代码与使用实例分析
- PHP的cURL库功能简介 抓取网页、POST数据及其他
- php curl 登录163邮箱并抓取邮箱好友列表的代码(经测试)
- The specified CGI application misbehaved by not returning a complete set of HTTP headers
- PHP stream_context_create()作用和用法分析