MASTG-TEST-0234 SSLSocket でのサーバーホスト名検証の実装の欠如 (Missing Implementation of Server Hostname Verification with SSLSockets)

概要

このテストは、Android アプリが HostnameVerifier なしで SSLSocket を使用し、不正または無効なホスト名 での証明書を提示するサーバーへの接続を許可しているかどうかをチェックします。

デフォルトでは、SSLSocketホスト名検証を実行しません。これを強制するには、アプリが明示的に HostnameVerifier.verify() を呼び出し、適切なチェックを実装する必要があります。

このような安全でない実装は、攻撃者が有効な (または自己署名された) 証明書で MITM 攻撃 を実行し、アプリのトラフィックを傍受または改竄することを可能にします。

注: アプリが完全に安全な Network Security Configuration (NSC) を有している場合でも、SSLSocket はその影響を受けないため、接続は成功します。

手順

  1. アプリをリバースエンジニアします (Java コードの逆コンパイル (Decompiling Java Code))。

  2. アプリに対して静的解析 (Android での静的解析 (Static Analysis on Android)) ツールを実行して、SSLSocketHostnameVerifier のすべての使用箇所を探します。

結果

出力には SSLSocketHostnameVerifier が使用されている場所のリストを含みます。

評価

アプリが HostnameVerifier なしで SSLSocket を使用している場合、そのテストケースは不合格です。

注: HostnameVerifier が存在する場合、それが安全でない方法で実装されていないことを確認してください。ガイダンスについては サーバーホスト名検証の正しくない実装 (Incorrect Implementation of Server Hostname Verification) を参照してください。

Last updated

Was this helpful?