已經獲取微信公眾號發布的圖片,但不能正常顯示 ,提示:此圖片來自微信公眾平臺 未經允許不得引用。
這是怎么回事呢?
遇到這種問題是因為微信公眾平臺對圖片采用了防盜鏈設置,微信對外提供了API接口,讓我們可以通過授權的方式獲取到自己公眾號里面的文章,或者你也可以通過爬蟲去抓取微信的文章,但是微信的圖片默認是不允許外部調用的
那該怎么解決這種問題呢?
這里我找到了兩種方案
第一種
在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等來跳過防盜鏈機制,但是這種方法,對代碼的結構影響很大,對一些移動類庫兼容性不太好。
第二種
運用用后臺方法
<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;
可看到結果,
目前我用第二種方法測試過,代碼簡單易懂,建議使用。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答