本日因为需要写一个挪用百度搜索图片的小插件,可是发明百度的图片都有防盗链的,假如不是百度自家网站利用,是不显示的。所以做了一个PHP的小文件,用来打破百度图片的防盗链。
直接利用百度图片链接如下面的图片链接
=2657861596,3149464998&fm=26&gp=0.jpg在欣赏器里直接打开如下
但假如在HTML网页中以IMG标签的要领挪用,如下
<img src="=2657861596,3149464998&fm=26&gp=0.jpg" />直接显示如下:
假如在网页中挪用,会触发图片的防盗链接机制,图片就不会正常显示。
办理要领在欣赏器的节制台中,可以查到百度图片的请求头,如下代码
Referer是header的一部门,当欣赏器向web处事器发送请求的时候,一般会带上Referer,汇报处事器该请求是从哪个页面链接过来的,假如来历的网址不属于本站或在黑名单中,则处事器不响应欣赏器的请求,到达了防盗链的目标。
我们可以操作PHP伪造一个请求的HEAD头,来打破百度图片的防盗链机制。
把以下代码生存为 img.php 文件
<?php $url = null; if(count($_GET) > 1){ foreach ($_GET as $key => $v) { if($key != 'url'){ $url .= '&'.$key.'='.$v; }else{ $url .= $v; } } }else{ $url = $_GET['url']; } //伪造 referer $refer = ''; $ch = curl_init($url); curl_setopt ($ch, CURLOPT_REFERER, $refer); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_BINARYTRANSFER, 1); $data = curl_exec($ch); curl_close($ch); header("Content-type: image/jpeg"); print($data); ?>然后在HTML网页如以下的要领挪用图片
<img src="img.php?url=http://img0.imgtn.bdimg.com/it/u=2657861596,3149464998&fm=26&gp=0.jpg" />挪用结果如下:.
ps:此种要领也可以用在其它一些有防盗链机制的网站,可以到达同样的结果。