500/udp - Pentesting IPsec/IKE VPN
Last updated
Last updated
AWSハッキングを学び、実践する:HackTricks Training AWS Red Team Expert (ARTE) GCPハッキングを学び、実践する:HackTricks Training GCP Red Team Expert (GRTE)
IPsecは、ネットワーク間(LAN-to-LAN)およびリモートユーザーからネットワークゲートウェイ(リモートアクセス)への通信を保護するための主要な技術として広く認識されており、企業VPNソリューションのバックボーンとして機能します。
2つのポイント間のセキュリティアソシエーション(SA)の確立は、認証と鍵交換のために設計されたプロトコルであるISAKMPの下で動作するIKEによって管理されます。このプロセスは、いくつかのフェーズで展開されます:
フェーズ1: 2つのエンドポイント間に安全なチャネルが作成されます。これは、事前共有鍵(PSK)または証明書を使用し、3対のメッセージを含むメインモードまたはアグレッシブモードを使用して達成されます。
フェーズ1.5: 必須ではありませんが、拡張認証フェーズとして知られるこのフェーズでは、ユーザー名とパスワードを要求することで接続を試みるユーザーの身元を確認します。
フェーズ2: このフェーズは、ESPおよびAHを使用してデータを保護するためのパラメータを交渉することに専念しています。これは、**完璧な前方秘匿性(PFS)**を確保するために、フェーズ1とは異なるアルゴリズムの使用を許可し、セキュリティを強化します。
デフォルトポート: 500/udp
IPSecの設定は、1つまたはいくつかの変換のみを受け入れるように準備できます。変換は値の組み合わせです。各変換には、暗号化アルゴリズムとしてのDESまたは3DES、整合性アルゴリズムとしてのSHAまたはMD5、認証タイプとしての事前共有キー、鍵の配布アルゴリズムとしてのDiffie-Hellman 1または2、有効期限としての28800秒などの属性が含まれています。
次に、最初に行うべきことは、有効な変換を見つけることです。そうすれば、サーバーがあなたと通信します。そのために、ツールike-scanを使用できます。デフォルトでは、Ike-scanはメインモードで動作し、ISAKMPヘッダーと8つの変換を含む単一の提案を持つパケットをゲートウェイに送信します。
応答に応じて、エンドポイントに関する情報を取得できます:
As you can see in the previous response, there is a field called AUTH with the value PSK. This means that the vpn is configured using a preshared key (and this is really good for a pentester). The value of the last line is also very important:
0 returned handshake; 0 returned notify: これはターゲットがIPsecゲートウェイではないことを意味します。
1 returned handshake; 0 returned notify: これはターゲットがIPsec用に設定されており、IKEネゴシエーションを行う意欲があり、提案した変換の1つ以上が受け入れ可能であることを意味します(有効な変換は出力に表示されます)。
0 returned handshake; 1 returned notify: VPNゲートウェイは、変換が受け入れ可能でない場合に通知メッセージで応答します(ただし、一部のゲートウェイはそうではないため、さらなる分析と修正された提案を試みる必要があります)。
次に、この場合、すでに有効な変換がありますが、3番目のケースにいる場合は、有効な変換を見つけるために少しブルートフォースする必要があります:
まず、すべての可能な変換を作成する必要があります:
そして、ike-scanを使用してそれぞれをブルートフォース攻撃します(これには数分かかる場合があります):
もしブルートフォースが機能しなかった場合、サーバーが有効なトランスフォームに対してもハンドシェイクなしで応答している可能性があります。その場合、攻撃的モードを使用して同じブルートフォースを試すことができます:
希望としては、有効な変換が返されることです。 iker.pyを使用して同じ攻撃を試すことができます。 ikeforceを使用して変換をブルートフォースすることも試すことができます:
DHグループ: 14 = 2048ビットMODPおよび15 = 3072ビット
2 = HMAC-SHA = SHA1(この場合)。--trans
形式は$Enc,$Hash,$Auth,$DHです。
Ciscoは、DHグループ1および2は強度が不十分であるため使用を避けるように指示しています。専門家は、資源の豊富な国々はこれらの弱いグループを使用するデータの暗号を簡単に破ることができると考えています。これは、コードを迅速に解読するために特別な方法を使用することによって行われます。この方法を設定するのには多くの費用がかかりますが、これによりこれらの強力な国々は、強度の低いグループ(例えば、1,024ビット以下)を使用している場合、暗号化されたデータをリアルタイムで読むことができます。
次に、ike-scanを使用してデバイスのベンダーを発見しようとすることができます。このツールは初期提案を送信し、再生を停止します。その後、受信したメッセージと一致する応答パターンとの時間の違いを分析することで、ペンテスターはVPNゲートウェイのベンダーを成功裏にフィンガープリンティングできます。さらに、一部のVPNサーバーはIKEでオプションのベンダーID(VID)ペイロードを使用します。
必要に応じて有効な変換を指定します(--transを使用)
IKEがベンダーを発見すると、それを印刷します:
これは nmap スクリプト ike-version を使っても達成できます。
ハッシュをキャプチャするためには、Aggressive モードをサポートする有効な変換と正しい ID (グループ名) が必要です。おそらく有効なグループ名はわからないので、ブルートフォースする必要があります。 そのために、2 つの方法をお勧めします。
まず、偽の ID でリクエストを試みてハッシュを収集します ("-P"):
もしハッシュが返されない場合、このブルートフォースの方法が機能する可能性があります。もしいくつかのハッシュが返された場合、これは偽のIDに対して偽のハッシュが返されることを意味するため、この方法はIDをブルートフォースするには信頼できません。例えば、偽のハッシュが返されることがあります(これは最新のバージョンで発生します):
しかし、私が言ったように、ハッシュが返されない場合は、ike-scanを使用して一般的なグループ名をブルートフォースすることを試みるべきです。
このスクリプトは可能なIDをブルートフォースし、有効なハンドシェイクが返されたIDを返します(これが有効なグループ名になります)。
特定の変換を発見した場合は、それをike-scanコマンドに追加してください。そして、いくつかの変換を発見した場合は、すべてを試すために新しいループを追加しても構いません(どれかが正しく機能するまで、すべてを試すべきです)。
一般的なグループ名をブルートフォースするために、ikeforceの辞書やseclistsの辞書を使用できます:
Or use this dict (is a combination of the other 2 dicts without repetitions):
iker.py は、ike-scanを使用して可能なグループ名をブルートフォースします。これは、ike-scanの出力に基づいて有効なIDを見つける独自の方法に従います。
ikeforce.py は、IDをブルートフォースするために使用できるツールです。このツールは、有効なIDと無効なIDを区別するために使用できるさまざまな脆弱性を悪用しようとします(偽陽性と偽陰性が発生する可能性があるため、可能であればike-scanメソッドを使用することを好みます)。
デフォルトでは、ikeforceは最初にサーバーの動作を確認し、使用する戦術を決定するためにいくつかのランダムなIDを送信します。
最初の方法は、CiscoシステムのDead Peer Detection DPDに関する情報を検索することによってグループ名をブルートフォースすることです(この情報は、グループ名が正しい場合にのみサーバーによって再生されます)。
利用可能な第二の方法は、各試行に送信された応答の数をチェックすることです。正しいIDが使用されると、より多くのパケットが送信されることがあります。
第三の方法は、不正なIDに対する応答で「INVALID-ID-INFORMATION」を検索することです。
最後に、サーバーがチェックに対して何も再生しない場合、ikeforceはサーバーをブルートフォースし、正しいIDが送信されたときにサーバーがパケットで応答するかどうかを確認します。 明らかに、IDをブルートフォースする目的は、有効なIDを持っているときにPSKを取得することです。その後、IDとPSKを使用してXAUTHをブルートフォースする必要があります(有効な場合)。
特定の変換を発見した場合は、それをikeforceコマンドに追加してください。また、複数の変換を発見した場合は、それらすべてを試すために新しいループを追加してください(すべてが正常に動作するまで試すべきです)。
(From the book Network Security Assessment: Know Your Network): VPNクライアントとサーバー間の接続をスニッフィングすることで、有効なユーザー名を取得することも可能です。クライアントIDを含む最初のアグレッシブモードパケットは平文で送信されます。
最後に、有効な変換とグループ名を見つけ、アグレッシブモードが許可されている場合、非常に簡単にクラック可能なハッシュを取得できます:
ハッシュは hash.txt に保存されます。
psk-crack、john(ikescan2john.py を使用)および hashcat を使用してハッシュをクラックできます:
攻撃的モード IKE は 事前共有鍵 (PSK) と組み合わせて グループ認証 の目的で一般的に使用されます。この方法は XAuth (拡張認証) によって強化され、追加の ユーザー認証 層を導入します。このような認証は通常、Microsoft Active Directory、RADIUS、または同様のシステムを利用します。
IKEv2 に移行すると、XAuth の代わりに EAP (拡張認証プロトコル) がユーザー認証の目的で使用される顕著な変化が見られます。この変更は、安全な通信プロトコル内での認証慣行の進化を強調しています。
したがって、fiked を使用してログインのデータをキャプチャし、デフォルトのユーザー名があるかどうかを確認できます(IKEトラフィックを fiked
にリダイレクトしてスニッフィングを行う必要があります。これはARPスプーフィングの助けを借りて行うことができます、詳細情報)。Fiked は VPN エンドポイントとして機能し、XAuth 資格情報をキャプチャします:
また、IPSecを使用してMitM攻撃を行い、ポート500へのすべてのトラフィックをブロックしてみてください。IPSecトンネルが確立できない場合、トラフィックはクリアで送信される可能性があります。
XAUTHをブルートフォースするには(有効なグループ名idとpskがわかっている場合)、ユーザー名またはユーザー名のリストとパスワードのリストを使用できます:
この方法で、ikeforceは各ユーザー名:パスワードの組み合わせを使用して接続を試みます。
有効な変換が1つまたは複数見つかった場合は、前のステップと同様にそれらを使用してください。
Kaliでは、VPNCを使用してIPsecトンネルを確立します。プロファイルはディレクトリ/etc/vpnc/
に配置する必要があります。これらのプロファイルはコマンド_vpnc_を使用して開始できます。
以下のコマンドと設定は、VPNCを使用してVPN接続を設定するプロセスを示しています:
このセットアップでは:
[VPN_GATEWAY_IP]
をVPNゲートウェイの実際のIPアドレスに置き換えます。
[VPN_CONNECTION_ID]
をVPN接続の識別子に置き換えます。
[VPN_GROUP_SECRET]
をVPNのグループシークレットに置き換えます。
[VPN_USERNAME]
と [VPN_PASSWORD]
をVPN認証情報に置き換えます。
[PID]
は vpnc
が開始されるときに割り当てられるプロセスIDを示します。
VPNを構成する際には、プレースホルダーを置き換えるために実際の安全な値を使用してください。
Network Security Assessment 3rd Edition
port:500 IKE
AWSハッキングを学び、練習する:HackTricks Training AWS Red Team Expert (ARTE) GCPハッキングを学び、練習する:HackTricks Training GCP Red Team Expert (GRTE)