php防盗链实例
防盗链是目前非常常见的web程序设计技巧。下面是小编分享的php防盗链实例,一起来看一下吧。
这里新建一个文件file.php。后面的参数就是需要伪造referfer的目标地址吧。如:file.php//pic/xxx.mp3
复制代码 代码如下:
<?
$url=str_replace('/file.php/','',$_SERVER["REQUEST_URI"]);/pic/p>
$downfile=str_replace(" ","",$url);/pic/p>
$downfile=str_replace("/pic/pic/pic/p>
$urlarr=explode("/",$downfile);/pic/"分解出域名
$domain=$urlarr[0];/pic/p>
$getfile=str_replace($urlarr[0],'',$downfile);/pic/p>
$content = @fsockopen("$domain", 80, $errno, $errstr, 12);/pic/p>
if (!$content){/pic/p>
die("对不起,无法连接上 $domain 。");
}
fputs($content, "GET $getfile HTTP/1.0rn");
fputs($content, "Host: $domainrn");
fputs($content, "Referer: $domainrn");/pic/p>
fputs($content, "User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)rnrn");
while (!feof($content)) {
$tp.=fgets($content, 128);
if (strstr($tp,"200 OK")){ /pic/110911/blog/item/21f20d2475af812ed50742c5.html这里是正常的文件请求状态,只需直接转向就可以。其他状态的继续执行程序
header("Location:$url");
die();
}
}
/pic/p>
$arr=explode("n",$tp);
$arr1=explode("Location: ",$tp);/pic/p>
$arr2=explode("n",$arr1[1]);
header('Content-Type:application/force-download');/pic/p>
header("location:".$arr2[0]);/pic/p>
die();
?>
这段程序只能针对使用referer来判断是否盗链的防盗链系统,使用其他特殊方法防盗链的,这个估计就不适用了
复制代码 代码如下:
$txt=$_GET['url'];
echo referfile($txt,'/pic/');
function referfile($url,$refer='') {
$opt=array('http'=>array('header'=>"Referer:$refer"));
$context=stream_context_create($opt);
Header("Location:".$url);
return file_get_contents($url,false,$context);
}
复制代码 代码如下:
<?php
$host = "pakey.net"; /pic/p>
$target = "/test.asp"; /pic/p>
$referer = "http/pic/"; /pic/p>
$fp = fsockopen($host, 80, $errno, $errstr, 30);
if(!$fp){
echo "$errstr($errno)<br /> ";
}else{
$out = "
GET $target HTTP/1.1
Host: $host
Referer: $referer
Connection: Close ";
fwrite($fp, $out);
while(!feof($fp)){
echo fgets($fp, 1024);
}
fclose($fp);
}
?>
【php防盗链实例】相关文章:
php画图实例03-19
php简单防盗链实现方法02-28
PHP防盗链的基本思想02-20
php防盗链的常用方法小结12-23
PHP实用的代码实例08-17
PHP socket的配置及实例03-21
php查询mysql的实例07-27
php中fsockopen用法实例08-14
php使用GeoIP库实例12-06