欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解微信圖片防盜鏈“此圖片來自微信公眾平臺 未經(jīng)允許不得引用”的解決方案

 更新時(shí)間:2019年04月04日 15:18:56   作者:lff1123  
這篇文章主要介紹了詳解微信圖片防盜鏈“此圖片來自微信公眾平臺 未經(jīng)允許不得引用”的解決方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

已經(jīng)獲取微信公眾號發(fā)布的圖片,但不能正常顯示 ,提示:此圖片來自微信公眾平臺 未經(jīng)允許不得引用。

 

這是怎么回事呢?

遇到這種問題是因?yàn)槲⑿殴娖脚_對圖片采用了防盜鏈設(shè)置,微信對外提供了API接口,讓我們可以通過授權(quán)的方式獲取到自己公眾號里面的文章,或者你也可以通過爬蟲去抓取微信的文章,但是微信的圖片默認(rèn)是不允許外部調(diào)用的

那該怎么解決這種問題呢?

這里我找到了兩種方案

第一種

在JS中提前把圖片加載到本地,然后從本地緩存中讀取圖片

var showImg = function (url) {
 var frameid = 'frameimg' + Math.random();
 window.img = '<img id="img" src=\'' + url + '?' + Math.random() + '\' /><script>window.onload = function() { parent.document.getElementById(\'' + frameid + '\').height = document.getElementById(\'img\').height+\'px\'; }<' + '/script>';
 return '<iframe id="' + frameid + '" src="javascript:parent.img;" frameBorder="0" scrolling="no" width="100%"></iframe>';
}

通過各種iframe,form等來跳過防盜鏈機(jī)制,但是這種方法,對代碼的結(jié)構(gòu)影響很大,對一些移動類庫兼容性不太好。

第二種

運(yùn)用用后臺方法

<img class="form_logo" src="{:U('showMpImg')}?url={$vo.url}" style="max-width: none" width="160" height="100">
//顯示圖片
  public function showMpImg($url){
    header('content_type:image/jpeg');
    echo file_get_contents($url);
  }

第三種,用php模擬瀏覽器請求

$url = $request->input('url');
$ch = curl_init();
$httpheader = array(
 'Host' => 'mmbiz.qpic.cn',
 'Connection' => 'keep-alive',
 'Pragma' => 'no-cache',
 'Cache-Control' => 'no-cache',
 'Accept' => 'textml,application/xhtml+xml,application/xml;q=0.9,image/webp,/;q=0.8',
 'User-Agent' => 'Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.89 Safari/537.36',
 'Accept-Encoding' => 'gzip, deflate, sdch',
 'Accept-Language' => 'zh-CN,zh;q=0.8,en;q=0.6,zh-TW;q=0.4'
);
$options = array(
 CURLOPT_HTTPHEADER => $httpheader,
 CURLOPT_URL => $url,
 CURLOPT_TIMEOUT => 5,
 CURLOPT_FOLLOWLOCATION => 1,
 CURLOPT_RETURNTRANSFER => true
);
curl_setopt_array( $ch , $options );
$result = curl_exec( $ch );
curl_close($ch);
header('Content-type: image/jpg');
echo $result;
exit;

可看到結(jié)果,

目前我用第二種方法測試過,代碼簡單易懂,建議使用。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JS實(shí)現(xiàn)網(wǎng)頁背景顏色與select框中顏色同時(shí)變化的方法

    JS實(shí)現(xiàn)網(wǎng)頁背景顏色與select框中顏色同時(shí)變化的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)網(wǎng)頁背景顏色與select框中顏色同時(shí)變化的方法,實(shí)例分析了javascript操作select及css樣式的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-02-02
  • javascript中的變量作用域以及變量提升詳細(xì)介紹

    javascript中的變量作用域以及變量提升詳細(xì)介紹

    在javascript中, 理解變量的作用域以及變量提升是非常有必要的。這個看起來是否很簡單,但其實(shí)并不是你想的那樣,還要一些重要的細(xì)節(jié)你需要理解
    2013-10-10
  • javascript 打印頁面代碼

    javascript 打印頁面代碼

    不用window.print實(shí)現(xiàn)的打印效果代碼。
    2009-03-03
  • 最新評論