php实现的网络相册图片防盗链完美破解方法
本文实例讲述了php实现的网络相册图片防盗链完美破解方法。分享给大家供大家参考。具体如下:
网络相册图片防盗链破解程序-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雪狐博客
*@version1.0
*@sinceJuly16,2012
*@URLhttp://www.xuehuwang.com
*/
classFrivoller
{
/**
*HTTP版本号(1.0,1.1),百度使用的是version1.1
*
*@varstring
*/
protected$version;
/**
*进行HTTP请求后响应的数据
*
*@var字符串格式
*/
protected$body;
/**
*需要获取的远程URL
*
*@var字符串格式
*/
protected$link;
/**
*AnarraythatcontaininganyofthevariouscomponentsoftheURL.
*
*@vararray
*/
protected$components;
/**
*HTTP请求时HOST数据
*
*@var字符串
*/
protected$host;
/**
*Thepathofrequiredfile.
*(e.g.'/verdana/abpic/item/mygirl.png')
*
*@varstring
*/
protected$path;
/**
*TheHTTPreferer,extraitfromoriginalURL
*
*@varstring
*/
protected$referer;
/**
*TheHTTPmethod,'GET'fordefault
*
*@varstring
*/
protected$method='GET';
/**
*TheHTTPport,80fordefault
*
*@varint
*/
protected$port=80;
/**
*Timeoutperiodonastream
*
*@varint
*/
protected$timeout=100;
/**
*Thefilenameofimage
*
*@varstring
*/
protected$filename;
/**
*TheContentTypeofimagefile.
*image/jpeg,image/gif,image/png,image
*
*@varstring
*/
protected$contentType;
/**
*Frivollerconstructor
*
*@paramstring$link
*/
publicfunction__construct($link,$referer='')
{
$this->referer=$referer;
//parsethehttplink
$this->parseLink($link);
//begintofetchtheimage
$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'headerforsavingthisfilecorrectly
//如果不发送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);
}
}
/**
*ComposeHTTPrequestheader
*
*@returnstring
*/
privatefunctionbuildHeaders()
{
$request="$this->method$this->pathHTTP/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;WindowsNT6.0;zh-CN;rv:1.9.0.1)Gecko/2008070208Firefox/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;
}
/**
*Stripinitialheaderandfilesizeinfo
*/
privatefunctionextractBody(&$body)
{
//Thestatusoflink
if(strpos($body,'200OK')>0){
//stripheader
$endpos=strpos($body,"\r\n\r\n");
$body=substr($body,$endpos+4);
//stripfilesizeatnextline
$body=substr($body,strpos($body,"\r\n")+2);
}
}
/**
*Extrathehttpurl
*
*@param$link
*/
privatefunctionparseLink($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);
//extractthecontenttype
$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';
}
}
//抓取网页内容
functionCurlGet($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;MSIE6.0;SeaPort/1.2;WindowsNT5.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;
}
}
/**
*取得根域名
*
*@authorlonely
*@create2011-3-11
*@version0.11
*@lastupdatelonely
*@packageSl
*/
classRootDomain{
privatestatic$self;
private$domain=null;
private$host=null;
private$state_domain;
private$top_domain;
/**
*取得域名分析实例
*Enterdescriptionhere...
*/
publicstaticfunctioninstace(){
if(!self::$self)
self::$self=newself();
returnself::$self;
}
publicfunction__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
*Enterdescriptionhere...
*@paramstring$url
*/
publicfunctionsetUrl($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'];
}elseif($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);
}elseif(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;
}
/**
*取得域名
*Enterdescriptionhere...
*/
publicfunctiongetDomain(){
return$this->domain;
}
/**
*取得主机
*Enterdescriptionhere...
*/
publicfunctiongetHost(){
return$this->host;
}
}
$referer=array('xuehuwang.com','zangbala.cn','qianzhebaikou.net','sinaapp.com','163.com','sina.com.cn','weibo.com','abc.com');
//Gettheurl,maybeyoushouldcheckthegivenurl
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=newRootDomain();
$root->setUrl($site);
if(in_array($root->getDomain(),$referer)){
$img_referer=(isset($_GET['referer'])&&!empty($_GET['referer']))?trim($_GET['referer']):'';
newFrivoller($_GET['url'],$img_referer);
}
}else{
$img_referer=(isset($_GET['referer'])&&!empty($_GET['referer']))?trim($_GET['referer']):'';
newFrivoller($_GET['url'],$img_referer);
}
}
}
?>
希望本文所述对大家的php程序设计有所帮助。