• 技术文章 >后端开发 >php教程

    php中突破基于HTTP_REFERER的防盗链措施(stream_context_create)_PHP教程

    2016-07-21 15:31:26原创381

    那么如果考虑突破防盗链的措施,就需要考虑在 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 将图片链接全部替换)。

    www.bkjia.comtruehttp://www.bkjia.com/PHPjc/322994.htmlTechArticle那么如果考虑突破防盗链的措施,就需要考虑在 HTTP_REFERER 上面做手脚了。PHP 脚本中对应的变量是 $_SERVER['HTTP_REFERER'] ,它存储了 HTTP_REFER...

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:php 突破 基于 HTTP REFERER 防盗 措施 stream context create 那么
    上一篇:php expects parameter 1 to be resource, array given 错误_PHP教程 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • 一文详解PHP用流方式实现下载文件(附代码示例)• PHP反序列化入门总结(小白必看)• PHP原生类的总结分享• 聊聊PHP escapeshellarg函数使用的中文问题• 分享PHP函数使用小工具(附代码示例)
    1/1

    PHP中文网