V13: 構成

管理目標

箱から出してすぐのアプリケーションの構成はインターネット上で安全であるべきです。つまり、そのままで安全な構成であるということです。

この章ではアプリケーションの開発時に適用する構成とビルドおよびデプロイ時に適用される構成の両方を含む、これを実現するために必要なさまざまな構成に関するガイダンスを提供します。

これには、データ漏洩の防止、さまざまなコンポーネント間の通信の安全な管理、シークレットの保護方法などのトピックを含みます。

V13.1 構成ドキュメント

このセクションでは、アプリケーションが外部サービスと通信する方法についてと、これらのサービスにアクセスできないことによる可用性の損失を防ぐために採用する必要がある技法についてのドキュメント要件を提供します。

#
説明
レベル
#v5.0.be

13.1.1

アプリケーションのすべての通信が文書化されている。これには、アプリケーションが依存する外部サービスや、アプリケーションが接続する外部ロケーションをエンドユーザが提供できる可能性がある場合を含む必要がある。

2

v5.0.be-1.14.7

13.1.2

アプリケーションが個別のサービスに接続する場合、アプリケーションのドキュメントには、各サービスへの最大可能並列接続数 (接続プール) と、この最大数に達した際のアプリケーションの応答方法を示し、サービス拒否状態を回避している。

3

v5.0.be-1.14.8

13.1.3

アプリケーションが個別のシステムリソースやサービス (データベース接続、ファイルやスレッドのオープンなど) に接続する場合、それぞれには、接続がタイムアウトする速度や再試行戦略など、文書化されたリソース解放および接続失敗戦略がある。これによりリソース枯渇を防いでいる。同期 HTTP リクエストレスポンスシナリオでの外部接続は、最大可能接続数に達することを避けるために、再試行せずにすぐに失敗する必要がある。

3

v5.0.be-1.14.9

V13.2 バックエンド通信構成

アプリケーションは、API、データベース、その他のコンポーネントを含む複数のサービスとやり取りする必要があります。これらはアプリケーションの内部とみなされるかもしれませんが、アプリケーションの標準アクセス制御メカニズムに含まれていないか、完全に外部かもしれません。いずれの場合も、これらのコンポーネントと安全にやり取りするようにアプリケーションを構成し、必要に応じてその構成を保護する必要があります。

#
説明
レベル
#v5.0.be

13.2.1

API、ミドルウェア、データレイヤなど、アプリケーションの標準ユーザセッションメカニズムをサポートしていないバックエンドアプリケーションコンポーネント間の通信は認証されている。認証は、パスワード、API キー、特権アクセスを備えた共有アカウントなどの不変のクレデンシャルではなく、個別のサービスアカウント、短期トークン、証明書ベースの認証を使用する必要がある。

2

v5.0.be-14.7.1

13.2.2

サービス認証にクレデンシャルを使用する必要がある場合、コンシューマが使用するデフォルトクレデンシャルではない (たとえば、一部のサービスではインストール時に root/root や admin/admin がデフォルトになる)。

2

v5.0.be-14.7.2

13.2.3

アプリケーションが外部のデータベースやサービスとの統合のためにパスワードや接続パラメータに関する構成の変更を許可する場合、それらは再認証や複数ユーザ承認などの特別なコントロールによって保護されている。

2

v5.0.be-14.7.3

13.2.4

Web サーバまたはアプリケーションサーバはサーバがリクエストを送信したり、データやファイルをロードできるリソースやシステムの許可リストで構成されている。

2

v5.0.be-14.7.4

13.2.5

ローカルまたはオペレーティングシステムのサービス、API、ミドルウェア、データレイヤなどのバックエンドアプリケーションコンポーネント間の通信は最小限の権限が割り当てられたアカウントで実行されている。

2

v5.0.be-14.7.5

13.2.6

アプリケーションが個別のサービスに接続する場合、最大並列接続数、最大許容接続数に達した際の動作、接続タイムアウト、再試行戦略など、各接続について文書化された構成に従っている。

3

v5.0.be-14.7.6

V13.3 シークレット管理

シークレット管理は、アプリケーションで使用されるデータの保護を確保するために不可欠な構成タスクです。暗号に関する具体的な要件は「暗号化」の章にありますが、このセクションではシークレットの管理と取り扱いの側面に焦点を当てています。

#
説明
レベル
#v5.0.be

13.3.1

key vault などのシークレット管理ソリューションは、バックエンドシークレットを安全に作成、保管、アクセス制御、破棄するために使用している。これには、パスワード、鍵マテリアル、データベースやサードパーティシステムとの統合、時間ベースのトークンのための鍵やシード、その他の内部セキュリティ、API キーなどを含む。シークレットはアプリケーションのソースコードやビルド成果物に含めてはいけない。L3 アプリケーションでは、これには HSM などのハードウェア支援のソリューションを含む必要がある。

2

v5.0.be-14.8.1

13.3.2

シークレット資産へのアクセスは最小権限の原則に従っている。

2

v5.0.be-14.8.4

13.3.3

鍵マテリアルはアプリケーション (フロントエンドでもバックエンドでも) には公開されないが、代わりに暗号操作のために vault などの分離されたセキュリティモジュールを使用している。

3

v5.0.be-14.8.2

13.3.4

重要なシークレットには有効期限が定義されており、組織の脅威モデルとビジネス要件に基づいたスケジュールでローテーションしている。

3

v5.0.be-14.8.3

V13.4 ビルドとデプロイ

ビルドプロセスのセキュリティと、関連する DevSecOps の側面は一般的に ASVS のスコープ外ですが、このセクションでは、アプリケーションのコンパイル方法やアプリケーションがデプロイされる際に不要なコンテンツを避けることなど、ビルドおよびデプロイプロセスで適用されるアプリケーション自体のセキュリティコントロールを取り上げます。

このセクションに準拠するには、自動ビルドシステムと、ビルドおよびデプロイメントスクリプトへのアクセスが必要です。

#
説明
レベル
#v5.0.be

13.4.1

デフォルトユーザーアカウント ("root", "admin", "sa" など) がアプリケーションに存在しないか、無効になっている。

1

v5.0.be-14.1.10

13.4.2

アプリケーションは .git や .svn フォルダなどのソース管理メタデータなしでデプロイされるか、またはこれらのフォルダが外部からもアプリケーション自体からもアクセスできない方法でデプロイされる。

1

v5.0.be-14.1.11

13.4.3

アプリケーションコードや機能は標準的な更新プロセスまたはビルドプロセスを通じてのみ変更可能であり、アプリケーション機能やその他の直接変更メカニズムを通じて本番環境で直接変更することはできない。

2

v5.0.be-14.1.9

13.4.4

スタックのランダム化、データ実行防止などの利用可能なすべてのバッファオーバーフローの保護と警告を有効にし、安全でないポインタ、メモリ、フォーマット文字列、整数、文字列操作が見つかった場合にビルドを中断するようにコンパイラフラグを設定している。

3

v5.0.be-14.1.2

13.4.5

すべてのサードパーティ製品、ライブラリ、フレームワーク、サービスにおいて、それぞれの推奨事項に従って、設定の堅牢化が実行されている。

3

v5.0.be-14.1.3

13.4.6

デプロイされた環境の有効期間が短く、頻繁に再デプロイされて「既知の良好な」更新された状態である。あるいは、有効期間が長い環境ではデプロイされた構成が安全でない状態に変更されないように、「ドリフト防止」メカニズムを持つ必要がある。

3

v5.0.be-14.1.5

13.4.7

すべての不要な機能、ドキュメント、サンプルアプリケーション、構成、ファイルやディレクトリのメタデータ (Thumbs.db、.DS_Store など) が削除されている。

3

v5.0.be-14.1.6

13.4.8

本番環境にテストコードが含まれていない。

3

v5.0.be-14.1.7

13.4.9

ビルドとデプロイメントプロセスに関連するデータ、状態情報、およびサーバーインスタンスはそのプロセスが終了した後には保持しない。 (一過性)

3

v5.0.be-14.1.8

V13.5 意図しない情報漏洩

不要なデータの開示を避けるために、本番用の構成を堅牢化する必要があります。これらの問題の多くは重大なリスクとして評価されることはほとんどありませんが、他の脆弱性と連鎖します。これらの問題がデフォルトで存在しない場合、アプリケーションを攻撃するハードルが上がり、攻撃者がより容易なターゲットを探すようになるかもしれません。

たとえば、サーバサイドコンポーネントのバージョンを非表示にしても、すべてのコンポーネントにパッチを適用する必要性がなくなるわけではありませんし、フォルダの一覧表示を無効にしても、認可コントロールを使用したり、パブリックフォルダからファイルを遠ざける必要性がなくなるわけではありませんが、ハードルを引き上げます。

#
説明
レベル
#v5.0.be

13.5.1

デバッグ機能の開示や意図しない情報漏洩を防ぐために、本番環境ではすべてのコンポーネントのデバッグモードが無効になっている。

2

v5.0.be-14.3.2

13.5.2

明確に必要でない限りディレクトリ参照が無効化されている。

2

v5.0.be-14.3.4

13.5.3

HTTP TRACE は潜在的な情報漏洩を避けるために無効化されている。

2

v5.0.be-14.3.6

13.5.4

アプリケーションはサーバサイドコンポーネントの詳細なバージョン情報を開示していない。

3

v5.0.be-14.3.3

13.5.5

意図しない情報漏洩やソースコード漏洩を防ぐために、Web 層が特定のファイル拡張子を持つファイルのみを処理するように設定されている。例えば、バックアップファイル (.bak) 、一時作業ファイル (.swp) 、圧縮ファイル (.zip, .tar.gz) やエディタで一般的に使用されるその他の拡張子は、必要でない限りブロックする必要がある。

3

v5.0.be-14.3.5

参考情報

詳しくは以下の情報を参照してください。

Last updated

Was this helpful?