>  기사  >  백엔드 개발  >  解决图片引用由于对方防盗链处理加载失败的解决方法

解决图片引用由于对方防盗链处理加载失败的解决方法

WBOY
WBOY원래의
2016-06-20 13:00:271849검색

解决图片引用由于对方防盗链处理加载失败的解决方法

 

现在很多图片网站都进行了防盗链处理,如果在你的网页中直接加载它们的图片会禁止访问或返回错误的图片。

一般没有好的解决办法,只能通过程序来读取图片然后在输出来,如果程序放在自己的服务器上,一方面负载会很高,另一方面速度会很慢,因为读取对方的图片,涉及网络传输等等。

有没有比较稳定的而且速度快的图片读取输出程序了,通过不断的努力,发现了在图片地址前面加上 http://read.html5.qq.com/image?src=forum&q=5&r=0&imgflag=7&imageUrl= ,这样就能解决问题。如果是动态输出的,如php程序则很好处理这个问题,正则匹配下,然后在地址前面加上 http://read.html5.qq.com/image?src=forum&q=5&r=0&imgflag=7&imageUrl= 就行了。

如果是静态的网页,如何来实现了。现在给出一个列子,加上一段js代码就行了,或者你讲js代码写入单独的文件中,然后在页面中引入执行下也行。



	<meta charset="UTF-8">
	<title>Document</title>


	<div>
		<img    style="max-width:90%" class="" src="http://img.xiumi.us/xmi/ua/77Lo/i/9d3d1481ba1067c000ad5f4db2013801-sz_183516.jpg@1l_640w.jpg" alt="解决图片引用由于对方防盗链处理加载失败的解决方法" >
	</div>

	<script type="text/javascript">
		//添加的代码,用于在图片地址前面加上指定字符串
		function showForbiddenImg(obj){
			for(var i=0;i<obj.length;obj++){
				if(!obj[i].getAttribute('img-src-f') && obj[i].getAttribute('src')){
					obj[i].setAttribute('img-src-f',obj[i].getAttribute('src'));
				}
				if(obj[i].getAttribute('img-src-f')){
					obj[i].setAttribute('src',(obj[i].getAttribute('img-src-f').indexOf('http://read.html5.qq.com')==-1) ? 'http://read.html5.qq.com/image?src=forum&q=5&r=0&imgflag=7&imageUrl='+obj[i].getAttribute('img-src-f') : obj[i].getAttribute('img-src-f'));
				}
			}
		}
		var img=document.getElementsByTagName('img');
		showForbiddenImg(img);
	</script>


 


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.