Swagger JSON高危漏洞被发现 Java/PHP/NodeJS/Ruby或中招

标题:

全方位防范 Swagger JSON 高危漏洞

背景介绍:

最近,一种针对 Swagger JSON 文件的高危漏洞被发现,这种漏洞可能让攻击者直接获取到应用程序的代码。这种漏洞已经影响到了 Java、PHP、NodeJS、Ruby 等多种语言,因此我们需要对此进行有效的防范。

攻击过程:

攻击者可能会通过修改Swagger文档,添加恶意逻辑来执行以下行动:

  1. 正常请求:用户正常调用应用API,恶意代码不单单返回请求结果数据,同时可能会对用户请求的返回结果进行篡改、数据拦截操作。

  2. 改动类型:攻击者感染服务端,修改对应接口或者函数类型,修改返回值,导致调用此API者抛出异常或者数据解析失败。

  3. 任意代码执行:攻击者可以通过对文档的细微修改,足以导致服务端执行恶意脚本,通过这些执行了恶意脚本,攻击者可以获取系统权限或者应用源代码。

防范措施:

  1. 尽量不要将swagger UI界面暴露在公网上。

  2. 对于Swagger静态文件的存储目录,尽量设置只读权限。

  3. 应用可以通过代码校验规避此类漏洞。

  4. 对swagger的输入参数进行校验,避免在文件载入时执行恶意代码。

下面我们详细介绍每一种防范措施的具体实现:

  1. 隐藏swagger UI

Swagger UI 经常被用来测试和浏览 API 文档,因此它会被暴露在互联网上。为了防止不必要的风险,可以将 Swagger UI 隐藏在内部网络中,或者启用身份验证机制来控制其访问。

  1. 只读权限设置

对于 Swagger 静态文件存储目录,尽量设置只读权限,以便确保在攻击者发现漏洞的情况下,他们无法轻易地修改 Swagger 文档。

  1. 代码规避

使用一些代码扫描工具,例如 CODE ANALYSIS 、FindSecBugs 等,以帮助验证 Swagger 文件的安全性。通过这些工具可以识别出 Swagger 文件中可能存在的安全漏洞,有效防范高危漏洞。

  1. 输入参数校验

在服务端代码构建之前,可以对 Swagger 的输入参数进行校验。通过校验输入参数,可以避免在文件载入时执行恶意代码,从而防止高危漏洞的发生。

示例说明:

以下代码演示了如何在 Node.js 中读取并验证 Swagger 文件的内容,避免其执行恶意代码:

const YAML = require("yamljs");
const fs = require("fs");

const filename = "swagger.yml";
const data = YAML.parse(fs.readFileSync(filename).toString());

if (data.securityDefinitions) {
  for (let [, value] of Object.entries(data.securityDefinitions)) {
    if (value.in && value.in === "header") {
      console.warn(
        "The `securityDefinitions` section contains a scheme that uses HTTP headers for authentication. Headers cannot be set from a Web page using XMLHttpRequest, CORS is enabled on the target server, and the Access-Control-Allow-Origin header does not allow the origin of the requesting page."
      );
    }
  }
} else {
  console.warn("No security schemes were found in the `securityDefinitions` section.");
}

代码中先使用 yamljs 模块读取Swagger文件内容,然后通过 onject.entries 检查 securityDefinitions 后循环检索到所有in: header的定义,检查后如果定义了in: header会输出警告信息并退出程序。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Swagger JSON高危漏洞被发现 Java/PHP/NodeJS/Ruby或中招 - Python技术站

(0)
上一篇 2023年5月26日
下一篇 2023年5月26日

相关文章

  • Java去除字符串中空格的方法详解

    Java去除字符串中空格的方法详解 在 Java 中,去除字符串中的空格是一个很常见的需求。本文将详细讲解如何实现去除字符串中空格的多种方法。 1. 使用replaceAll方法 replaceAll 方法是 String 类提供的方法,它可以将字符串中的一个字符或一组字符全部替换成另一个字符或一组字符。我们可以利用它来去除字符串中的空格。 下面是一个示例代…

    Java 2023年5月26日
    00
  • Java深入理解代码块的使用细节

    Java 深入理解代码块的使用细节 代码块的定义 代码块是指被一对大括号包含起来的代码段,其中包括了定义变量、方法、循环、分支等语句。 Java中的代码块可以分为以下两种: 实例代码块 实例代码块是定义在类中的非静态代码块,可以用于初始化实例变量。实例代码块会在构造方法执行前执行。 实例代码块的示例代码如下: public class Demo { priv…

    Java 2023年5月20日
    00
  • SpringMVC返回图片的几种方式(小结)

    SpringMVC返回图片的几种方式(小结) 在SpringMVC中,我们可以使用多种方式返回图片。本文将介绍三种常用的方式:使用ResponseEntity返回图片、使用@ResponseBody注解返回图片、使用HttpServletResponse输出流返回图片。 使用ResponseEntity返回图片 以下是一个使用ResponseEntity返回…

    Java 2023年5月17日
    00
  • spring中的FactoryBean代码示例

    FactoryBean是Spring中一个非常重要的接口,常用于实例化非Bean类型对象或实例化有状态的Bean对象。在使用FactoryBean时,需要实现该接口并实现其中的方法,让Spring容器在初始化Bean时通过FactoryBean实现对Bean的创建和定制化处理。 1. 定义FactoryBean 在Spring中定义FactoryBean需要…

    Java 2023年5月31日
    00
  • 方法区的作用是什么?

    以下是关于 Java 方法区的详细讲解和使用攻略: 方法区的作用是什么? Java 方法区是一种用于存储已加载类信息、常量、静态变量、即时编编译后的代码数据的内存区域。方法区是线程共享的,其大小可以通过 -XX:MetaspaceSize 参数进行设置。 方法区的使用攻略 使用 Java 方法区,需要注意以下几点: 在程序开发中,需要合理使用内存,避免出现内…

    Java 2023年5月12日
    00
  • 深入了解Java8中的时区日期时间

    关于“深入了解Java8中的时区日期时间”的攻略,我将从以下几个方面进行详细讲解: 时区概念介绍 Java8中的时区 日期时间的表示和操作 时区转换和格式化 时区概念介绍 时区是一个地球上的地区,为方便起见,划分为24个标准时区,每个时区以相对于格林威治标准时间的小时数进行标记。时区与地球上的经度有密切关系,通常是基于一个参考点来描述小时数。例如,北京的时区…

    Java 2023年5月20日
    00
  • java统计字符串中重复字符出现次数的方法

    要统计字符串中重复字符的出现次数,可以采用以下的方法: 1. 利用Map统计字符出现次数 首先我们可以定义一个Map来存储每个字符出现的次数,然后遍历字符串中每个字符,并通过Map统计该字符的出现次数。 例如以下的Java代码: public static void countDuplicateChars(String str) { Map<Chara…

    Java 2023年5月27日
    00
  • 在Java代码中解析html,获取其中的值方法

    要在Java代码中解析html,获取其中的值,可以使用Jsoup这个第三方开源库。下面是使用Jsoup的步骤: 第一步:导入Jsoup库 使用Maven导入依赖: <dependency> <groupId>org.jsoup</groupId> <artifactId>jsoup</artifactId…

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