亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術(shù)文章
文章詳情頁

PHP實(shí)現(xiàn)圖片防盜鏈破解操作示例【解決圖片防盜鏈問題/反向代理】

瀏覽:126日期:2022-09-10 09:45:56

本文實(shí)例講述了PHP實(shí)現(xiàn)圖片防盜鏈破解操作。分享給大家供大家參考,具體如下:

很多小伙伴的博客,網(wǎng)站都是用圖床來實(shí)現(xiàn)的,那么現(xiàn)在很多穩(wěn)定的圖床接口都被做了防盜鏈處理,例如百度、阿里、京東、小米、搜狗等。

所以我們應(yīng)該怎么避開防盜鏈直接使用圖片呢?

1 防盜的原理是什么?

當(dāng)客戶端(瀏覽器)向服務(wù)器請求內(nèi)容的時候,會提交一個header,這個header中包含了如:瀏覽器信息、cookie等內(nèi)容,那么有一個叫referer的東東,也包含在這里面。

referer是干啥用的呢?

它就是告訴服務(wù)器,這個請求的來源是誰,比如:從頁面A跳轉(zhuǎn)到頁面B,那么頁面B收到的referer就是頁面A。

但是在圖片身上和這個有點(diǎn)不同,圖片是在html頁面加載完畢后才加載的,所以圖片收到的referer不是網(wǎng)頁的上一個頁面,而是當(dāng)前頁面。

說這么多,不要被說繞了,簡單點(diǎn)就是:對于圖片而言,收到的referer就是引用圖片的這個網(wǎng)頁的網(wǎng)址。

那么現(xiàn)在的很多網(wǎng)站是如何利用referer來進(jìn)行防圖片盜鏈的呢?

三種情況下允許引用圖片:

本網(wǎng)站。 無referer信息的情況。(服務(wù)器認(rèn)為是從瀏覽器直接訪問的圖片URL,所以這種情況下能正常訪問) 白名單網(wǎng)址。開始做防盜鏈處理

1、需要有一個服務(wù)器2、代碼使用php

<?php class ImgBridge{ private $water=’’; private $imgUrl=’’; private $referer=’’; private $ua=’MQQBrowser/26 Mozilla/5.0 (Linux; U; Android 2.3.7; zh-cn; MB200 Build/GRJ22; CyanogenMod-7) AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1’; private $imgCode=’’; private $imgHeader=’’; private $imgBody=’’; private $imgType=’’; public function __construct($config=array()){ foreach($config as $key=>$value){ $this->$key=$value; } } public function getImg($imgUrl){ $this->imgUrl=$imgUrl; /** 處理url */ if(substr($this->imgUrl,0,7)!==’http://’ && substr($this->imgUrl,0,8)!==’https://’){ $this->imgUrl=’http://’.$this->imgUrl; } /** 解析url中的host */ $url_array=parse_url($this->imgUrl); /** 設(shè)置referer */ $this->referer=$this->referer==''?’http://’.$url_array[’host’]:$this->referer; /**開始獲取 */ $this->urlOpen(); $this->imgBody; /**處理錯誤 */ if($this->imgCode!=200){ $this->error(1); exit(); }/**獲取圖片格式 */ preg_match('/Content-Type: image/(.+?)n/sim',$this->imgHeader,$result); /**看看是不是圖片 */ if(!isset($result[1])){ $this->error(2); exit(); }else{ $this->imgType=$result[1]; } /** 輸出內(nèi)容 */ $this->out(); } private function out(){ /** gif 不處理,直接出圖 */ if($this->imgType==’gif’){ header('Content-Type: image/gif'); echo $this->imgBody; exit(); } header('Content-Type: image/png'); /** 其他類型的,加水印 */ $im=imagecreatefromstring($this->imgBody); $white = imagecolorallocate($im, 255, 255, 255); /*加上水印*/ if($this->water){ imagettftext($im, 12, 0, 20, 20, $white, '/fonts/hwxh.ttf', $this->water); } imagepng($im); } private function error($err){ header('Content-Type: image/jpeg'); $im=imagecreatefromstring(file_get_contents(’./default.jpg’)); imagejpeg($im); } private function urlOpen() { $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $this->imgUrl); curl_setopt($ch, CURLOPT_USERAGENT, $this->ua); curl_setopt ($ch,CURLOPT_REFERER,$this->referer); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_HEADER, 1); /**跳轉(zhuǎn)也要 */ curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); /** 支持https */ $opt[CURLOPT_SSL_VERIFYHOST] = 2; $opt[CURLOPT_SSL_VERIFYPEER] = FALSE; curl_setopt_array($ch, $opt); $response = curl_exec($ch); $this->imgCode=curl_getinfo($ch, CURLINFO_HTTP_CODE) ; if ($this->imgCode == ’200’) { $headerSize = curl_getinfo($ch, CURLINFO_HEADER_SIZE); $this->imgHeader = substr($response, 0, $headerSize); $this->imgBody = substr($response, $headerSize); return ; } curl_close($ch); } }$img=new ImgBridge(array(’water’=>’’));$img->getImg(strstr($_SERVER['QUERY_STRING'], 'http'));

代碼命名為dl.php

那么直接可以訪問

http://域名/dl.php?url=防盜鏈圖片地址

下面是我部署的反向代理

http://www.likeyunba.com/2.php?url=

請不要拿我的直接用,我的不會長期放著的,只保留短暫1-2個月用于給你們體驗(yàn)。

案例

我用135編輯器上傳一張圖片,獲得圖片地址

https://image.135editor.com/files/users/740/7407329/201912/zTeFAx8R_Cmea.jpg

加上反向代理,破解防盜鏈處理

http://www.likeyunba.com/2.php?url=https://image.135editor.com/files/users/740/7407329/201912/zTeFAx8R_Cmea.jpg

HTML格式

<img src='http://www.likeyunba.com/2.php?url=https://image.135editor.com/files/users/740/7407329/201912/zTeFAx8R_Cmea.jpg' />

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP圖形與圖片操作技巧匯總》、《PHP數(shù)組(Array)操作技巧大全》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《php字符串(string)用法總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家PHP程序設(shè)計有所幫助。

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 在线观看日本永久免费视频 | 怡红院老首页主页入口 | 国产成人艳妇在线观看 | 国产精品久久久久久麻豆一区 | 国产91免费| 国产精品三级国语在线看 | 手机成人看片 | 成人久久18免费游戏网站 | 一级一片免费播放 | 一级女性黄 色生活片 | 亚洲免费色视频 | 小泽玛利亚的一级毛片的 | 福利视频黄 | 欧美成人高清视频 | 亚洲韩国欧美一区二区三区 | 久久久网站 | 欧美aaaaaabbbbb| 欧美中文字幕 | 日韩特级片 | 成人男女18免费o | 国产欧美日韩精品a在线观看 | 国产一区二区三区手机在线观看 | 欧洲成人全免费视频网站 | 99这里只有精品视频 | 波多野一区二区三区在线 | 国产精品一级片 | 国产欧美日韩视频免费61794 | 精品丝袜国产自在线拍亚洲 | 亚洲在线观看免费 | 久久成人网18网站 | 男女视频免费 | 久久国产美女免费观看精品 | 在线免费公开视频 | 日韩中文字 | 日本毛片在线 | 欧美巨大video粗暴 | www.成人在线视频 | 欧美13一14sexvideo欧 | 久久久久欧美精品网站 | 亚洲毛片免费观看 | 娇小性色xxxxx中文 |