部分网站允许空白referer的防盗链图片的js破解代码

为了防止恶意网站站点盗取自己的资源,很多网站都会设置防盗链,限制只有自己网站的页面可以访问这些资源。其中一个最常用的防盗链方式是检测请求的referer字段,如果不符合条件则拒绝访问。referer字段记录了当前请求来源的URL地址,一般情况下只有在通过链接点击进入目标页面时referer才会非空。

而某些网站会允许访问者通过空referer字段访问一些资源,可以通过JavaScript代码破解这样的防盗链机制。下面是实现这种破解代码的步骤:

  1. 发起一次请求,获取响应对象。
var xhr = new XMLHttpRequest();
xhr.open('GET', 'http://example.com/xxx.jpg', true);
xhr.send(null);
  1. 设置当前页面访问xxx.jpg的referer字段为空。
xhr.setRequestHeader('Referer', '');
  1. 将响应对象的responseType属性设置为'blob',以便获取二进制数据的Blob对象。
xhr.responseType = 'blob';
  1. 当服务器成功响应后,使用URL.createObjectURL()方法获取Blob对象的URL。
xhr.onload = function() {
    if (this.status == 200) {
        var imgBlob = this.response;
        var imgURL = URL.createObjectURL(imgBlob);
        var img = document.createElement('img');
        img.src = imgURL;
        document.body.appendChild(img);
    }
};

这样,就可以成功在页面上加载防盗链图片。

下面是两个示例:

  1. 支持空referer的网站示例:https://www.linuxidc.com/upload/2019_09/190926143561052.jpg
    在该网站上,任何页面都可以通过空referer字段进行访问。可以使用下面的JavaScript代码破解防盗链并在页面上显示图片:
var xhr = new XMLHttpRequest();
xhr.open('GET', 'https://www.linuxidc.com/upload/2019_09/190926143561052.jpg', true);
xhr.setRequestHeader('Referer', '');
xhr.responseType = 'blob';
xhr.onload = function() {
    if (this.status == 200) {
        var imgBlob = this.response;
        var imgURL = URL.createObjectURL(imgBlob);
        var img = document.createElement('img');
        img.src = imgURL;
        document.body.appendChild(img);
    }
};
xhr.send(null);
  1. 不支持空referer的网站示例:https://img-blog.csdn.net/20180814091815280?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3F6aGxvbmc5OTk2/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/q/80
    在该网站上,只有从特定页面才能访问图片。通过referer字段检测,如果当前请求的referer不正确,则返回403错误。因此,即使使用上面的JavaScript代码也无法成功加载图片。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:部分网站允许空白referer的防盗链图片的js破解代码 - Python技术站

(0)
上一篇 2023年6月15日
下一篇 2023年6月15日

相关文章

  • SpringBoot使用RESTful接口详解

    SpringBoot使用RESTful接口详解 什么是RESTful接口 RESTful是一种基于HTTP协议实现的Web服务的架构风格,其常用于构建分布式的网络应用程序和服务。RESTful接口设计的核心是资源的定义和状态的转换,它通过使用HTTP协议规定的方法(GET、POST、PUT、DELETE等),操作网络上的资源。HTTP中的资源可以是任何东西,…

    Java 2023年5月20日
    00
  • kaptcha验证码组件使用简介解析

    首先给出一份包含标题、正文内容和示例代码的markdown文本: Kaptcha验证码组件使用简介解析 Kaptcha是一款Java语言编写的验证码组件,可以非常方便地为Web应用添加验证码保护。它支持自定义验证码样式,包括验证码字符、字体、大小、颜色、背景等,同时还具备多语言支持、音频验证码功能以及代码简单等优点。 在下面的示例中,我们将详细讲解如何使用K…

    Java 2023年6月15日
    00
  • 如何使用Java Instrumentation API?

    如何使用Java Instrumentation API Java Instrumentation API是Java平台提供的一个高级工具,用于在运行时修改或监视Java应用程序的字节码。具体来说,Instrumentation API允许我们在JVM启动应用程序之前动态地修改类定义和字节码。这使得我们能够增强应用程序的功能,例如在应用程序执行过程中收集性能…

    Java 2023年5月11日
    00
  • 教你在一分钟之内理解Java Lambda表达式并学会使用

    教你在一分钟之内理解Java Lambda表达式并学会使用 什么是Lambda表达式 Lambda表达是Java 8引入的一种新特性,是一种简化代码的语法结构。它可以用来创建简洁、可读性强的函数式代码,适合于函数式编程。 Lambda表达式实际上是一个匿名函数,它不需要声明函数,直接在需要使用的地方定义即可。 Lambda表达式的语法 Lambda表达式的语…

    Java 2023年5月26日
    00
  • 教你使用springSecurity+jwt实现互踢功能

    我会从以下几个方面讲解如何使用Spring Security和JWT实现互踢功能: Spring Security和JWT简介 实现互踢功能的思路 配置Spring Security和JWT 实现互踢功能的示例 防止并发登录 防止token重复使用 Spring Security和JWT简介 Spring Security是基于Spring框架的安全框架,提…

    Java 2023年5月20日
    00
  • JSP自定义标签案例分析

    让我来详细讲解一下“JSP自定义标签案例分析”的完整攻略。 什么是JSP自定义标签 首先要明确什么是JSP自定义标签。JSP自定义标签可以让我们自己定义一些标签,然后在JSP页面中使用这些标签。这些标签可以用来封装一些复杂的逻辑,方便页面的开发和维护。JSP自定义标签分为两种类型:标签库描述文件和标签处理器。 标签库描述文件 标签库描述文件是用来描述自定义标…

    Java 2023年6月15日
    00
  • java对象序列化与反序列化的默认格式和json格式使用示例

    Java对象序列化和反序列化是Java中常用的数据交换方式,其中序列化是将Java对象转换为字节流,可以储存到文件或网络流中,反序列化则是将字节流转换为Java对象。在Java中,序列化和反序列化的默认格式是二进制格式,而JSON格式则更加通用并且易于阅读。 默认格式的使用示例 序列化 当我们需要将一个Java对象进行序列化时,我们可以使用 ObjectOu…

    Java 2023年5月26日
    00
  • Java函数式编程(六):Optional

    Java函数式编程(六):Optional Optional简介 在Java 8中,Optional成为了一个非常重要的新特性。Optional是一个容器类型,代表一个值存在或不存在。Original Java中,我们经常返回null来表示一个空值。但是在Java 8 中使用Optional来表示一个值不存在更加明确和安全。 Optional 类(java.…

    Java 2023年5月26日
    00
合作推广
合作推广
分享本页
返回顶部