チュートリアル: ウェブアプリケーションをスキャンするようにDASTをセットアップする
動的アプリケーションセキュリティテスト(DAST)をCI/CDパイプラインに統合する方法を学習します。
静的な解析は、ソースコード内の脆弱性を発見します。DASTは、アプリケーションが実際の環境で実行され、サービスやユーザーワークフローとやり取りするときにのみ現れるランタイムセキュリティ問題を特定します。GitLabと統合されたDASTソリューションを使用すると、テスト環境にコードをデプロイするたびに、GitLab DASTをセットアップしてこれらの問題を自動的にチェックできます。
このチュートリアルでは、次のことを学習します:
このチュートリアルで示すTanuki Shopアプリケーションは、認証を必要としません。アプリケーションにログインが必要な場合は、DAST認証を参照してください。
はじめる前
- GitLab Ultimateサブスクリプション。
- プロジェクトのメンテナーロール。
Tanuki Shopアプリケーションをセットアップする
まずTanuki Shopをフォークすることから始めます。
Tanuki Shopリポジトリにアクセスします。
右上隅で、フォークを選択します。
ネームスペース(個人またはグループ)を選択し、プロジェクトをフォークを選択します。
フォークしたリポジトリには、アプリケーションコードと初期CI/CD設定を含む、このチュートリアルに必要なすべてのファイルが含まれています。以下のステップで設定を変更します。
設定 > 一般にアクセスします。
可視性、プロジェクトの機能、権限を展開します。
コンテナレジストリの切替がオンになっていることを確認してください。
コンテナレジストリが機能していることを確認します:
- デプロイ > コンテナレジストリにアクセスします。
- 空のレジストリが表示されるはずです。エラーが表示される場合は、プロジェクトの権限を確認してください。
コンテナレジストリは、パイプラインでビルドされたDockerイメージを保存します。このステップが失敗すると、ビルドジョブは後で失敗します。
ビルドジョブを定義する
ここで、アプリケーションを含むDockerイメージを作成し、コンテナレジストリにプッシュするようにビルドジョブを設定します。
プロジェクトで、
.gitlab-ci.ymlファイルを編集します。既存のコンテンツを次のCI/CD設定に置き換えます:
stages: - build - dast include: - template: Security/DAST.gitlab-ci.yml # Build: Create the Docker image and push to the container registry build: services: - name: docker:dind alias: dind image: docker:20.10.16 stage: build script: - docker login -u gitlab-ci-token -p $CI_JOB_TOKEN $CI_REGISTRY - docker pull $CI_REGISTRY_IMAGE:latest || true - docker build --tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA --tag $CI_REGISTRY_IMAGE:latest . - docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA - docker push $CI_REGISTRY_IMAGE:latest
DASTジョブを定義する
ビルドジョブを設定したら、DASTジョブを設定します。
この設定は、サービス機能を使用して、アプリケーションコンテナをDASTジョブと並行して実行します。アプリケーションは、URL http://yourapp:3000のdastジョブからアクセスできます。
DASTジョブを設定するには:
.gitlab-ci.ymlファイルの下部に次を追加します:# DAST: Scan the application running in a Docker container dast: services: - name: $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA alias: yourapp variables: DAST_TARGET_URL: http://yourapp:3000
パッシブスキャンとアクティブスキャンを設定する
DASTは、セキュリティカバレッジとスキャン時間のバランスをとる2つのスキャンモードをサポートしています。パッシブスキャンは迅速なフィードバックを提供します。アクティブスキャンは、アプリケーションが細工されたリクエストでテストされた場合にのみ現れる脆弱性を発見し、コードが本番環境に到達する前に、より徹底したセキュリティ検証を提供します。
パッシブスキャン(デフォルト、約2~5分):
- 潜在的に有害なリクエストを送信せずに、アプリケーションの応答を分析します
- HTTPヘッダー、クッキー、応答コンテンツ、およびSSL/TLS設定を検査します
- あらゆる環境で安全に実行できます
- CI/CDパイプラインでの迅速なフィードバックに適しています
アクティブスキャン(アプリケーションのサイズに応じて約10~30分):
- 脆弱性をトリガーするように設計された細工されたリクエストを送信します
- インジェクションの欠陥、認証の問題、およびビジネスロジックの脆弱性をテストします
- より徹底的ですが、速度は遅いです
- mainにマージする前のフィーチャーブランチに最適です
DASTスキャンを本番環境サーバーに対して実行しないでください。ユーザーが行えるあらゆる機能(ボタンの選択やフォームの送信など)を実行できるだけでなく、バグをトリガーする可能性もあり、本番環境データの変更や損失につながる可能性があります。テストサーバーに対してのみDASTスキャンを実行してください。
パッシブスキャンとアクティブスキャンを設定するには:
.gitlab-ci.ymlファイルの下部に次を追加します:rules: - if: $CI_COMMIT_REF_NAME == $CI_DEFAULT_BRANCH variables: DAST_FULL_SCAN: "false" # Passive scan only for main branch (~2-5 mins) - if: $CI_COMMIT_REF_NAME != $CI_DEFAULT_BRANCH variables: DAST_FULL_SCAN: "true" # Active scan for feature branches (~10-30 mins)
セットアップを検証する
DASTが実行中のアプリケーションで脆弱性を正常に発見できることを確認してください。
パイプラインエディタで、変更をコミットするを選択し、
gitlabブランチにコミットします。パイプラインがすぐに開始されます。
ビルド > パイプラインにアクセスし、最新のパイプラインが正常に完了したことを確認します。
予想タイムライン:
- ビルドステージ: 2~3分(Dockerイメージの構築)
- DASTステージ: 2~5分(パッシブスキャン)
パイプラインが正常に完了したら、セキュリティ > 脆弱性レポートにアクセスします。
脆弱性を確認してください。各脆弱性への対処方法については、脆弱性を修正する方法を参照してください。
Tanuki Shopアプリケーションは、デモンストレーション目的で意図的に脆弱性があります。セキュリティポリシー、個人を特定できる情報(PII)の露呈、その他の一般的なウェブ脆弱性に関連する発見が表示されるはずです。
次の手順
このチュートリアルを完了すると、次のことができるようになります:
- 特定の要件に合わせて、高度なDAST設定を構成できます。
- アドホックテスト用にオンデマンドDASTスキャンを設定できます。
- DASTを脆弱性管理ワークフローと統合します。
- その他の例については、DASTデモリポジトリを参照してください。
トラブルシューティング
ビルドジョブが認証エラーで失敗する
認証エラーは、コンテナレジストリの認証情報が利用できない場合に発生します。
この問題を解決するには、以下の手順に従います:
コンテナレジストリが有効になっていることを確認します:
- 設定 > 一般にアクセスします。
- 可視性、プロジェクトの機能、権限を展開します。
- コンテナレジストリの切替がオンになっていることを確認してください。
プロジェクトに有効なCI/CDトークンがあることを確認してください。GitLabは
$CI_REGISTRY_USERと$CI_REGISTRY_PASSWORDを自動的に提供します。
DASTジョブは完了するが脆弱性が発見されない
この問題は、DASTがアプリケーションに到達できない場合、またはアプリケーションに脆弱性がない場合に発生します。
この問題を解決するには、次の手順に従います:
アプリケーションが実行されていることを確認します:
curl "http://yourapp:3000"接続に関連するエラーがないかDASTジョブログを確認してください。
DAST_TARGET_URL変数が正しく設定されていることを確認してください(http://yourapp:3000である必要があります)。Tanuki Shopアプリケーションには脆弱性があるはずです。見つからない場合は、正しいフォークしたリポジトリを使用していることを確認してください。