这篇文章主要介绍了
防盗链和破解
防盗链的办法,有自己的主机一般都会设计"防盗链", 其实包括图片防盗链,和下载防盗链等,如:
1.使用.htaccess设置防盗链
RewriteEngine on
RewriteCond %{HTTP_REFERER} !^$
RewriteCond %{HTTP_REFERER} !^http://(www\.)?genban.org/.*$ [NC]
RewriteRule \.(gif|jpg)$ //www.genban.org/image.gif [R,L]
2.nginx设置防盗链
location ~* \.(gif|jpg|png|swf|flv)$ {
valid_referers none blocked genban.org;
if ($invalid_referer) {
rewrite ^/ http://genban.org/234_s.gif;
#return 404;
}
}
但怎么破解防盗链呢? 一般的防盗链是判断来路是否为自己的域名, 我们可以使用 php 内置的 file_get_contents 方法来请求这个图片(当然别的后端语言也有类似的方法), 如:
<?php
$url=empty($_GET['url'])?'':trim(urldecode($_GET['url']));
if(empty($url))die('?url=');
$new_name = new_name($url);
if(file_exists($new_name)){header('location:'.$new_name);return;}
$type = get_type($url);
header('Content-type: image/'.$type);
$content = file_get_contents($url);
//file_put_contents($new_name,$content);
echo $content;
function new_name($url){
$url = strtr($url,array(':'=>'','//'=>'','/'=>'_'));
return 'uploads/cache/'.$url;
}
function get_type($url){
$type=substr(strrchr($url,"."),1);
if(in_array($type,array('png','gif','bmp','webp')))return $type;
return 'jpeg';
}
?>
1、直接加载防盗链图片:(该站未授权的图片显示都是空白)
2、 通过php读取图片,就可以直接显示出来图片了.对于一般的防盗链情况是没有问题的特殊情况再考虑吧