文档章节

如何直接引用微信的图片链接详解

浮雲
 浮雲
发布于 2017/08/31 17:28
字数 603
阅读 35
收藏 0

欢迎扫码加入Java高知群交流

以微信的一个图片链接为例子:http://mmbiz.qpic.cn/mmbiz_jpg/azXQmS1HA7m80L8HYB1Jfdqicn4LMgfejKp4Nkia6ZyExOJURicRg6HibN7aBcWxSkCTicCkbRIQgprO33Q2TsHFT9Q/640?wx_fmt=jpeg&tp=webp&wxfrom=5&wx_lazy=1

微信图片做了防盗链处理,如果直接引用图片的src地址,会提示如下信息:

网上查询了一下,有的说是用qq的一个链接能解决:

http://read.html5.qq.com/image?src=forum&q=5&r=0&imgflag=7&imageUrl=xxx

其中imageUrl是需要访问微信图片的链接,之前也测试过这个方法确实可行,但是现在腾讯做了更严格的防盗,所以现在这种方式也不行了。

那有没有更好的办法呢?我们发现,直接copy微信图片的链接到浏览器敲回车是可以正常的展示图片出来的,估计是通过Referer来判断,如果是非本站的Referer会进行拦截,

直接copy到浏览器地址栏是不带有Referer的,对不带Referer的请求貌似没限制,本人猜测的。通过iframe可以请求图片不携带Referer,虽然效率上和体验上没那么好,但是图片这样是可以展示出来的。如下图:

那么讲了这么多,大家最关心的问题还是代码怎么实现,其实很简答,通过js动态生成iframe即可,代码如下:

 

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<html>
    <head>
    <title>test</title>
	<script src="js/common/jquery-1.8.3.min.js"></script>
	<script type="text/javascript">
	</script>
    </head>
    <body>
    <img src="http://mmbiz.qpic.cn/mmbiz_jpg/AiaMTYUYjYNa0mibnn2ay6luBGXPBRSV2ibJic3uGYickID3OUkvKzAC2E0ibVWSNicpykkpUqALFicSiaibgO0XyYWlEhGQ/640?wx_fmt=jpeg&tp=webp&wxfrom=5&wx_lazy=1">
    <script>
	    function showImg(url) {
	        var imgid = Math.random(),frameid = 'frameimg' + imgid;
	        window['img'+imgid] = '<img id="img" src=\''+url+'\' />' +
	                        '<script>window.onload = function(){' +
	                        'parent.document.getElementById(\''+frameid+'\').width=document.getElementById(\'img\').width+\'px\';' +
	                        'parent.document.getElementById(\''+frameid+'\').height=document.getElementById(\'img\').height+\'px\';' +
	                        '}<'+'/script>';
	        return '<iframe id="'+frameid+'" src="javascript:parent[\'img'+imgid+'\'];" frameBorder="0" scrolling="no" width="100%"></iframe>';
	    }
    </script>
    <script type="text/javascript">
    	//$("img").hide();
        var imgs = document.getElementsByTagName('img');
        for(var i=0;i<imgs.length;i++){
            var data_src = $(imgs[i]).attr("src");
            var html = showImg("http://read.html5.qq.com/image?src=forum&q=5&r=0&imgflag=7&imageUrl="+data_src);
            $(imgs[i]).replaceWith(html);
        }
    </script>
    </body>
</html>

 

 

 

 

 

体验上来说确实不是很好,各位大神有什么更好的其它办法可以底下留言交流交流。

 

还有一种简单的方法就是直接在页面的head中添加<meta name="referrer" content="never">,

但是这样所有的请求都不会带referrer,有点自宫的感觉。

 

欢迎扫码加入Java高知群交流

本文转载自:http://blog.csdn.net/tjcyjd/article/details/74643521

共有 人打赏支持
浮雲
粉丝 0
博文 7
码字总数 811
作品 0
海淀
陈晓通20:一键批量下载公众号文章的图片,还能下载任何网页的图片,超级好用

如何快速搜图找图?几乎每个新媒体从业者,会经常去思考和研究。 却很少人关注,如何快速下载保存图片? 下载图片都是一张一张“另存为图片”的方式来下载,下载完了还要一张一张改属性格式、...

陈晓通
2017/07/13
0
0
Java垃圾回收(GC)机制详解

如何找到要回收的垃圾 1、引用计数法 2、可达性分析法 三、四种引用状态 1、强引用 2、软引用 3、弱引用 4、虚引用 五、垃圾收集算法 1、标记-清除(Mark-Sweep)算法 2、复制(Copying)算法...

细节探索者
04/26
0
0
腾讯技术分享:Android版手机QQ的缓存监控与优化实践

本文内容整理自公众号腾讯Bugly,感谢原作者的分享。 1、问题背景 对于Android应用来说,内存向来是比较重要的性能指标。内存占用过高,会影响应用的流畅度,甚至引发OOM,非常影响用户体验。...

JackJiang2011
04/08
0
0
简书 Markdown 语法详解

注: 文章摘自 白老师课堂 - 简书 一、区块标记 区块标记:是指内容独占一块,需前后换行,不和其他标记共处一行的标记 1. 段落 段落:即是一段连续的文字,可包含 * 、空格、换行、tab 等字符...

小贤笔记
08/16
0
0
微信开放微信内网页开发工具包,助力网页开发

微信公众平台今日面向开发者开放微信内网页开发工具包(微信JS-SDK)。 通过微信JS-SDK提供的11类接口集,开发者不仅能够在网页上使用微信本身的拍照、选图、语音、位置等基本能力,还可以直...

oschina
2015/01/10
26.2K
30

没有更多内容

加载失败,请刷新页面

加载更多

记一次winserver2003系统,https无法访问,内存占用持续增加,解决办法

先交代一下环境: win server2003系统,系统装在hyper-v虚拟机里 大概2016年底的镜像,距离今天两年左右 病症:大概9月10号左右用这个镜像还可以访问https,但是今天用这个镜像新装的系统,就...

阳阳露
4分钟前
0
0
jdbc连接orcal数据库

import java.sql.Connection;  import java.sql.DriverManager;  import java.sql.ResultSet;  import java.sql.SQLException;  import java.sql.Statement;    ......

小橙子的曼曼
29分钟前
0
0
Vue学习资料

一直以为Vue是依赖nodejs的。 作为前端也可以耦合性就很低了。 //npm包管理器 进行管理npm install vue//初始化一个项目vue init//本地调试npm run dev//编译完成 ...

大灰狼wow
39分钟前
1
0
fullcalendar重新渲染

uiCalendarConfig.calendars.lesson_calendar.fullCalendar('removeEvents');var ym = uiCalendarConfig.calendars.lesson_calendar.fullCalendar('getView').title;$scope.get_lesson(y......

人来疯啊
43分钟前
1
0
多渠道打包总结

https://www.jianshu.com/p/2130db7584c8 https://blog.csdn.net/u011153817/article/details/50772496...

塔塔米
52分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部