백엔드 개발 PHP 튜토리얼 PHP解决网络相册图片防盗链

PHP解决网络相册图片防盗链

Jun 20, 2016 pm 01:01 PM

网络相册图片防盗链破解程序 - PHP版 这个防盗链破解版可以完美破解当下比较流行的: 百度相册,网易相册,360我喜欢等网站图片. 还可以实现简单的图片防盗链. 因为这个类是先进行获取远程图片, 然后再把图片发送到客户端,所以,算是进行了两次流量的传送.因此,会浪费空间流量,接下来,会开发缓存功能,这样可以实现节约流量!

<?php   
/**    
 * 网络相册图片防盗链破解程序 - PHP版    
 *     
 * 使用方法:     
 *      
 *      http://yourdomain/url.php?url=http://hiphotos.baidu.com/verdana/pic/item/baidupicture.jpg&referer=    
 *      其中url是指需要破解的图片URL,而referer是为了兼容一些不需要设置来路域名才能显示的相册,例如360我喜欢网,必须设置来路为空才能正常浏览. 所以,此时应该设置referer为1   
 *    
 * @author  雪狐博客    
 * @version 1.0    
 * @since   July 16, 2012   
 * @URL http://www.xuehuwang.com    
 */
            
class Frivoller    
{    
    /**    
     * HTTP 版本号 (1.0, 1.1) , 百度使用的是 version 1.1    
     *    
     * @var string    
     */
    protected $version;    
           
    /**    
     * 进行HTTP请求后响应的数据   
     *     
     * @var 字符串格式    
     */
    protected $body;    
                
    /**    
     * 需要获取的远程URL   
     *     
     * @var 字符串格式    
     */
    protected $link;    
           
    /**    
     * An array that containing any of the various components of the URL.     
     *    
     * @var array    
     */
    protected $components;    
           
    /**    
     * HTTP请求时HOST数据   
     *    
     * @var 字符串    
     */
    protected $host;    
           
    /**    
     * The path of required file.    
     * (e.g. '/verdana/abpic/item/mygirl.png')    
     *    
     * @var string    
     */
    protected $path;    
           
    /**    
     * The HTTP referer, extra it from original URL    
     *    
     * @var string    
     */
    protected $referer;    
           
    /**    
     * The HTTP method, 'GET' for default    
     *    
     * @var string    
     */
    protected $method   = 'GET';    
           
    /**     
     * The HTTP port, 80 for default    
     *     
     * @var int    
     */
    protected $port     = 80;    
           
    /**    
     * Timeout period on a stream    
     *     
     * @var int    
     */
    protected $timeout  = 100;    
           
    /**    
     * The filename of image    
     *    
     * @var string    
     */
    protected $filename;    
           
    /**    
     * The ContentType of image file.    
     * image/jpeg, image/gif, image/png, image    
     *     
     * @var string    
     */
    protected $contentType;    
           
    /**    
     * Frivoller constructor    
     *    
     * @param string $link    
     */
    public function __construct($link,$referer='')    
    {    
        $this->referer = $referer;   
        // parse the http link    
        $this->parseLink($link);    
                   
        // begin to fetch the image    
        $stream = pfsockopen($this->host, $this->port, $errno, $errstr, $this->timeout);    
        if (!$stream){   
            header("Content-Type: $this->contentType;");    
            echo $this->CurlGet($link);    
        }else{    
            fwrite($stream, $this->buildHeaders());    
            $this->body = "";    
            $img_size = get_headers($link,true);   
            while (!feof($stream)) {    
                $this->body .= fgets($stream, $img_size['Content-Length']);    
                //fwrite($jpg,fread($stream, $img_size['Content-Length']));   
            }    
            $content = explode("\r\n\r\n", $this->body, 2);    
            $this->body = $content[1];   
            fclose($stream);      
               
            // send 'ContentType' header for saving this file correctly    
            // 如果不发送CT,则在试图保存图片时,IE7 会发生错误 (800700de)    
            // Flock, Firefox 则没有这个问题,Opera 没有测试    
            header("Content-Type: $this->contentType;");    
            header("Cache-Control: max-age=315360000");   
            echo $this->body;        
                       
               
             //保存图片   
             //file_put_contents('hello.jpg', $this->body);    
        }   
                   
    }    
           
           
    /**    
     * Compose HTTP request header    
     *     
     * @return string     
     */
    private function buildHeaders()    
    {    
        $request  = "$this->method $this->path HTTP/1.1\r\n";    
        $request .= "Host: $this->host\r\n";    
        $request .= "Accept-Encoding: gzip, deflate\r\n";   
        $request .= "User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.0; zh-CN; rv:1.9.0.1) Gecko/2008070208 Firefox/3.0.1\r\n";   
        $request .= "Content-Type: image/jpeg\r\n";    
        $request .= "Accept: */*\r\n";    
        $request .= "Keep-Alive: 300\r\n";    
        $request .= "Referer: $this->referer\r\n";    
        $request .= "Cache-Control: max-age=315360000\r\n";    
        $request .= "Connection: close\r\n\r\n";    
        return $request;    
    }    
           
           
    /**    
     * Strip initial header and filesize info    
     */    
    private function extractBody(&$body)    
    {         
        // The status of link    
        if(strpos($body, '200 OK') > 0) {    
           
            // strip header    
            $endpos = strpos($body, "\r\n\r\n");    
            $body = substr($body, $endpos + 4);    
           
            // strip filesize at nextline    
            $body = substr($body, strpos($body, "\r\n") + 2);    
        }            
    }    
           
           
    /**    
     * Extra the http url    
     *     
     * @param $link    
     */
    private function parseLink($link)    
    {    
        $this->link         = $link;    
        $this->components   = parse_url($this->link);    
        $this->host         = $this->components['host'];    
        $this->path         = $this->components['path'];    
        if(empty($this->referer)){   
            $this->referer      = $this->components['scheme'] . '://' . $this->components['host'];    
        }elseif($this->referer  == '1'){   
            $this->referer      = '';   
        }   
        $this->filename     = basename($this->path);    
                    
        // extract the content type    
        $ext = substr(strrchr($this->path, '.'), 1);    
        if ($ext == 'jpg' or $ext == 'jpeg') {    
            $this->contentType  = 'image/pjpeg';    
        }    
        elseif ($ext == 'gif') {    
            $this->contentType  = 'image/gif';    
        }    
        elseif ($ext == 'png') {    
            $this->contentType  = 'image/x-png';    
        }    
        elseif ($ext == 'bmp') {    
            $this->contentType  = 'image/bmp';    
        }    
        else {    
            $this->contentType  = 'application/octet-stream';    
        }    
    }    
    //抓取网页内容    
    function CurlGet($url){    
        $url = str_replace('&','&',$url);    
        $curl = curl_init();    
        curl_setopt($curl, CURLOPT_URL, $url);    
        curl_setopt($curl, CURLOPT_HEADER, false);    
                   
        curl_setopt($curl, CURLOPT_REFERER,$url);    
        curl_setopt($curl, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 6.0; SeaPort/1.2; Windows NT 5.1; SV1; InfoPath.2)");    
        curl_setopt($curl, CURLOPT_COOKIEJAR, 'cookie.txt');    
        curl_setopt($curl, CURLOPT_COOKIEFILE, 'cookie.txt');    
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);    
        curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 0);    
        $values = curl_exec($curl);    
        curl_close($curl);    
        return $values;    
    }    
           
}    
/**   
 * 取得根域名   
 *   
 * @author     lonely   
 * @create        2011-3-11   
 * @version    0.11   
 * @lastupdate lonely   
 * @package Sl   
*/
class RootDomain{   
     private static $self;   
    private $domain=null;   
    private $host=null;   
    private $state_domain;   
    private $top_domain;   
    /**   
     * 取得域名分析实例   
     * Enter description here ...   
     */
    public static function instace(){   
        if(!self::$self)   
            self::$self=new self();   
        return self::$self;   
    }   
    public function  __construct(){   
        $this->state_domain=array(   
            'al','dz','af','ar','ae','aw','om','az','eg','et','ie','ee','ad','ao','ai','ag','at','au','mo','bb','pg','bs','pk','py','ps','bh','pa','br','by','bm','bg','mp','bj','be','is','pr','ba','pl','bo','bz','bw','bt','bf','bi','bv','kp','gq','dk','de','tl','tp','tg','dm','do','ru','ec','er','fr','fo','pf','gf','tf','va','ph','fj','fi','cv','fk','gm','cg','cd','co','cr','gg','gd','gl','ge','cu','gp','gu','gy','kz','ht','kr','nl','an','hm','hn','ki','dj','kg','gn','gw','ca','gh','ga','kh','cz','zw','cm','qa','ky','km','ci','kw','cc','hr','ke','ck','lv','ls','la','lb','lt','lr','ly','li','re','lu','rw','ro','mg','im','mv','mt','mw','my','ml','mk','mh','mq','yt','mu','mr','us','um','as','vi','mn','ms','bd','pe','fm','mm','md','ma','mc','mz','mx','nr','np','ni','ne','ng','nu','no','nf','na','za','aq','gs','eu','pw','pn','pt','jp','se','ch','sv','ws','yu','sl','sn','cy','sc','sa','cx','st','sh','kn','lc','sm','pm','vc','lk','sk','si','sj','sz','sd','sr','sb','so','tj','tw','th','tz','to','tc','tt','tn','tv','tr','tm','tk','wf','vu','gt','ve','bn','ug','ua','uy','uz','es','eh','gr','hk','sg','nc','nz','hu','sy','jm','am','ac','ye','iq','ir','il','it','in','id','uk','vg','io','jo','vn','zm','je','td','gi','cl','cf','cn','yr'
        );   
        $this->top_domain=array('com','arpa','edu','gov','int','mil','net','org','biz','info','pro','name','museum','coop','aero','xxx','idv','me','mobi');   
        $this->url=$_SERVER['HTTP_HOST'];   
    }   
    /**   
     * 设置URL   
     * Enter description here ...   
     * @param string $url   
     */
    public function setUrl($url=null){   
        $url=$url?$url:$this->url;   
        if(empty($url))return $this;   
        if(!preg_match("/^http:/is", $url))   
            $url="http://".$url;   
        $url=parse_url(strtolower($url));   
        $urlarr=explode(".", $url['host']);   
        $count=count($urlarr);   
                   
        if ($count<=2){   
            $this->domain=$url['host'];   
        }else if ($count>2){   
            $last=array_pop($urlarr);   
            $last_1=array_pop($urlarr);   
            if(in_array($last, $this->top_domain)){   
                $this->domain=$last_1.'.'.$last;   
                $this->host=implode('.', $urlarr);   
            }else if (in_array($last, $this->state_domain)){   
                $last_2=array_pop($urlarr);   
                if(in_array($last_1, $this->top_domain)){   
                    $this->domain=$last_2.'.'.$last_1.'.'.$last;   
                    $this->host=implode('.', $urlarr);   
                }else{   
                    $this->host=implode('.', $urlarr).$last_2;   
                    $this->domain=$last_1.'.'.$last;   
                }   
            }   
        }   
        return $this;   
    }   
    /**   
     * 取得域名   
     * Enter description here ...   
     */
    public function getDomain(){   
        return $this->domain;   
    }   
    /**   
     * 取得主机   
     * Enter description here ...   
     */
    public function getHost(){   
        return $this->host;   
    }   
}   
$referer = array('xuehuwang.com','zangbala.cn','qianzhebaikou.net','sinaapp.com','163.com','sina.com.cn','weibo.com','abc.com');   
           
// Get the url, maybe you should check the given url    
if (isset($_GET['url']) and $_GET['url'] != '') {    
               
    //获取来路域名   
    $site = (isset($_SERVER['HTTP_REFERER']) && !empty($_SERVER['HTTP_REFERER'])) ? $_SERVER['HTTP_REFERER'] : '';   
               
    //匹配是否是一个图片链接   
    if(preg_match('/(http|https|ftp|rtsp|mms):(\/\/|\\\\){1}((\w)+[.]){1,}([a-zA-Z]|[0-9]{1,3})(\S*\/)((\S)+[.]{1}(gif|jpg|png|bmp))/i',$_GET['url'])){   
        if(!empty($site)){   
            $tempu = parse_url($site);   
            $host = $tempu['host'];   
            $root = new RootDomain();   
            $root->setUrl($site);   
            if(in_array($root->getDomain(),$referer)){   
                $img_referer = (isset($_GET['referer']) && !empty($_GET['referer']))? trim($_GET['referer']) : '';   
                new Frivoller($_GET['url'],$img_referer);    
            }   
        }else{   
            $img_referer = (isset($_GET['referer']) && !empty($_GET['referer']))? trim($_GET['referer']) : '';   
            new Frivoller($_GET['url'],$img_referer);    
        }   
    }   
}    
?>
로그인 후 복사

 


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄) 11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄) Mar 03, 2025 am 10:49 AM

11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄)

Instagram API 소개 Instagram API 소개 Mar 02, 2025 am 09:32 AM

Instagram API 소개

Laravel의 플래시 세션 데이터로 작업합니다 Laravel의 플래시 세션 데이터로 작업합니다 Mar 12, 2025 pm 05:08 PM

Laravel의 플래시 세션 데이터로 작업합니다

Laravel Back End : Part 2, React가있는 React 앱 구축 Laravel Back End : Part 2, React가있는 React 앱 구축 Mar 04, 2025 am 09:33 AM

Laravel Back End : Part 2, React가있는 React 앱 구축

Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Mar 12, 2025 pm 05:09 PM

Laravel 테스트에서 단순화 된 HTTP 응답 조롱

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 Mar 14, 2025 am 11:42 AM

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Mar 13, 2025 pm 12:08 PM

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트

라 라벨에서 알림 라 라벨에서 알림 Mar 04, 2025 am 09:22 AM

라 라벨에서 알림

See all articles