【转载】通过JS破解图片防盗链限制

本文介绍了一种使用JavaScript破解允许空白referer防盗链图片的方法,并提供了实现代码。同时,探讨了三种防御策略:限制referer、地址变更和登录校验。

  首先看下效果,以下两张图分别使用直接盗链和破解盗链,可以右键查看图片URL,是同一张图片。

直接盗链

破解盗链

  实现代码:

function showImg( 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>';
        document.write('<iframe id="' frameid '" src="javascript:parent.img;" frameBorder="0" scrolling="no" width="100%"></iframe>');
}

  调用方式:

showImg('图片地址');

  关于防御方法,有以下3点:

  1、不允许referer为空(不建议,因在某些开启隐私模式的浏览器中,或https页面引用下,referer是空的)
  2、地址变更(lighttpd的是根据有效时间,nginx的根据是md5)
  3、登录校验(如必须登录网站帐号后才能访问)

  原文链接:javascript 破解允许空白referer的防盗链图片

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值