次の方法で共有


Visual Studio を使用した ASP.NET Web 配置: テスト環境へのデプロイ

著者: Tom Dykstra

このチュートリアル シリーズでは、Visual Studio 2017 を使用して、ASP.NET Web アプリを Azure App Service Web Apps またはサードパーティのホスティング プロバイダーにデプロイ (発行) する方法について説明します。 このシリーズについては、シリーズの最初のチュートリアルをご覧ください。

Azure へのデプロイの現在のバージョンについては、Azure での ASP.NET Core Web アプリの作成に関するページを参照してください。

概要

このチュートリアルでは、ASP.NET Web アプリをローカル コンピューター上のインターネット インフォメーション サービス (IIS) にデプロイします。

通常、アプリケーションをデプロイする場合、Visual Studio で実行してテストします。 既定では、Visual Studio 2017 の Web アプリ プロジェクトでは、開発 Web サーバーとして IIS Express が使用されます。 Visual Studio 2017 が既定で使用する Visual Studio 開発サーバー (Cassini とも呼ばれます) よりも IIS Express の方が、完全な IIS に似た動作をします。 ただし、どちらの開発 Web サーバーも IIS とまったく同じようには機能しません。 そのため、Visual Studio でアプリを正しく実行してテストできても、IIS にデプロイすると失敗します。

アプリケーションを確実にテストするには、次の 2 つの方法があります。

  1. 後で運用環境にデプロイするときに使用するプロセスと同じプロセスを使用して、アプリケーションを開発用コンピューター上の IIS に展開します。

    Web プロジェクトの実行時に IIS を使用するように Visual Studio を構成できますが、デプロイ プロセスはテストされません。 この方法では、デプロイ プロセスと、アプリケーションが IIS で正しく実行されることを検証します。

  2. アプリケーションを運用環境と同様のテスト環境にデプロイします。

    これらのチュートリアルの運用環境は、Azure App Service 内の Web Apps です。 理想的なテスト環境は、Azure サービスで作成された追加の Web アプリです。 これは、運用環境の Web アプリと同じ方法で設定されますが、テストにのみ使用します。

オプション 2 は、最も信頼性の高いテスト方法です。 オプション 2 を使用する場合、必ずしもオプション 1 を使用する必要はありません。 ただし、サードパーティのホスティング プロバイダーにデプロイする場合、オプション 2 は実現できないか、コストがかかる可能性があるため、このチュートリアル シリーズでは両方の方法を示します。 オプション 2 のガイダンスは、運用環境へのデプロイに関するチュートリアルで提供されています。

Visual Studio で Web サーバーを使用する方法の詳細については、「ASP.NET Web プロジェクト用の Visual Studio の Web サーバー」を参照してください。

注意: チュートリアルを進める際にエラー メッセージが表示される場合、または何かが機能しない場合は、必ずトラブルシューティングのページを確認してください。

Contoso University スターター プロジェクトをダウンロードする

Contoso University Visual Studio スターター ソリューションとプロジェクトをダウンロードしてインストールします。 このソリューションには、完成したチュートリアルが含まれています。

スタート プロジェクトをダウンロードする

IIS のインストール

開発用コンピューター上の IIS にデプロイするには、IIS と Web 配置がインストールされていることを確認します。 既定では、Visual Studio は Web 配置をデプロイしますが、IIS は、既定の Windows 10、Windows 8、または Windows 7 の構成に含まれていません。 IIS を既にインストールしており、既定のアプリケーション プールが既に .NET 4 に設定されている場合は、次のセクションに進んでください。

  1. Web Platform Installer (WPI) を使用して IIS と Web 配置をインストールすることをお勧めします。 WPI を使用すると、必要に応じて IIS と Web 配置の前提条件を含む推奨される IIS 構成がインストールされます。

    IIS、Web 配置、またはいずれかの必要なコンポーネントを既にインストールしている場合、WPI は、不足しているもののみをインストールします。

    • Web Platform Installer を使用して IIS と Web 配置をインストールします。

      WPI を使用して IIS をインストールする

      WPI を使用して Web 配置をインストールする

      IIS 7 がインストールされることを示すメッセージが表示されます。 このリンクは、Windows 8 の IIS 8 では機能しますが、Windows 8 以降の場合は、次の手順を実行して、ASP.NET 4.7 がインストールされていることを確認します。

    • [コントロール パネル]>[プログラム]>[プログラムと機能]>[Windows の機能の有効化または無効化]の順に開きます。

    • [インターネット インフォメーション サービス][World Wide Web サービス][アプリケーション開発機能] の順に展開します。

    • [ASP.NET 4.7] がオンになっていることを確認します。

      ASP.NET 4.7 を選択する

    • [World Wide Web サービス][IIS 管理コンソール] がオンになっていることを確認します。 これにより、IIS と IIS マネージャーがインストールされます。

      World Wide Web サービスを選択する

    • [OK] を選択します。 インストール中であることを示すダイアログ ボックス メッセージが表示されます。

IIS をインストールしたら、IIS マネージャーを実行して、.NET Framework バージョン 4 が既定のアプリケーション プールに割り当てられていることを確認します。

  1. WINDOWS + R キーを押して、[実行] ダイアログ ボックスを開きます

    (Windows 8 以降では、[スタート] ページに「実行」と入力します。Windows 7 では、[スタート] メニューから [実行] を選択します。[スタート] メニューに [実行] がない場合、タスク バーを右クリックし、[プロパティ][スタート メニュー] タブ、[カスタマイズ][実行コマンド] の順に選択します)。

  2. 「inetmgr」と入力し、[OK] を選択します。

  3. [接続] ペインで、サーバー ノードを展開し、[アプリケーション プール] を選択します。 [アプリケーション プール] ペインで、次の図のように、DefaultAppPool が .NET Framework バージョン 4 に割り当てられている場合は、次のセクションに進みます。

    Inetmgr_showing_4.0_app_pools

  4. 2 つのアプリケーション プールのみが表示され、両方とも .NET Framework 2.0 に設定されている場合は、IIS に ASP.NET 4 をインストールします。

    Windows 8 以降の場合は、ASP.NET 4.7 がインストールされていることを確認するための前のセクションの手順を参照するか、Windows 8 と Windows Server 2012 に ASP.NET 4.5 をインストールする方法に関するページを参照してください。 Windows 7 の場合は、Windows の [スタート] メニューの [コマンド プロンプト] を右クリックし、[管理者として実行] を選択して、コマンド プロンプト ウィンドウを開きます。 次のコマンドを使用して、aspnet_regiis.exe を実行し、ASP.NET 4 を IIS にインストールします (32 ビット システムでは、"Framework64" を "Framework" に置き換えます)。

    cd %windir%\Microsoft.NET\Framework64\v4.0.30319
    aspnet_regiis.exe –i
    

    このコマンドを実行すると、.NET Framework 4 用の新しいアプリケーション プールが作成されますが、既定のアプリケーション プールは 2.0 に設定されたままになります。 .NET 4 を対象とするアプリケーションをそのアプリケーション プールにデプロイしているため、アプリケーション プールを .NET 4 に変更します。

  5. IIS マネージャーを閉じている場合は、もう一度実行し、サーバー ノードを展開して、[アプリケーション プール] を選択します。

  6. [アプリケーション プール] ペインで、[DefaultAppPool] を選択します。 [アクション] ペインで、[基本設定] を選択します。

    Inetmgr_selecting_Basic_Settings_for_app_pool

  7. ][アプリケーション プールの編集] ダイアログ ボックスで、[.NET CLR のバージョン][.NET CLR v4.0.30319] に変更します。 [OK] を選択します。

    Selecting_.NET_4_for_DefaultAppPool

これで、Web アプリを IIS に発行する準備ができました。 ただし、まず、テスト用のデータベースを作成します。

SQL Server Express をインストールする

LocalDB は IIS で動作するように設計されていないため、テスト環境には SQL Server Express がインストールされている必要があります。 Visual Studio 2010 SQL Server Express を使用している場合は、既定で既にインストールされています。 Visual Studio 2012 以降を使用している場合は、SQL Server Express をインストールします。

SQL Server Express をインストールするには、ダウンロード センター: Microsoft SQL Server 2017 Express Edition からダウンロードしてインストールします。

SQL Server インストール センターの最初のページで、[新しい SQL Server スタンドアロン インストール] を選択するか、既存のインストールに機能を追加し、手順に従って既定の選択を受け入れます。 インストール ウィザードで、既定の設定を受け入れます。 インストール オプションの詳細については、「SQL Server をインストール ウィザードからインストールする (セットアップ)」を参照してください。

テスト環境用の SQL Server Express データベースを作成する

Contoso University アプリケーションには、次の 2 つのデータベースがあります。

  1. メンバーシップ データベース
  2. アプリケーション データベース

これらのデータベースを 2 つの個別のデータベースまたは 1 つのデータベースにデプロイできます。 これらを組み合わせると、これらの間のデータベース結合が容易になります。

サードパーティのホスティング プロバイダーにデプロイする場合、ホスティング プランのために、これらを組み合わせる必要が生じる場合もあります。 たとえば、プロバイダーが、複数のデータベースに対して追加料金を請求する場合や、複数のデータベースを許可しない場合などがあります。

このチュートリアルでは、テスト環境では 2 つのデータベースにデプロイし、ステージング環境と運用環境では 1 つのデータベースにデプロイします。

Visual Studio の [表示] メニューから [サーバー エクスプローラー] (Visual Web Developer では [データベース エクスプローラー]) を選択します。 [データ接続] を右クリックし、[新しい SQL Server データベースの作成] を選択します。

Selecting_Create_New_SQL_Server_Database

[新しい SQL Server データベースの作成] ダイアログ ボックスで、[サーバー名] ボックスに「.\SQLExpress」と入力し、[新しいデータベース名] ボックスに「aspnet-ContosoUniversity」と入力します。 [OK] を選択します。

aspnet-ContosoUniversity の作成

同じ手順に従って、ContosoUniversity という名前の新しい SQL Server Express School データベースを作成します。

サーバー エクスプローラー に 2 つの新しいデータベースが表示されます。

サーバー エクスプローラーの新しいデータベース

新しいデータベースの許可スクリプトを作成する

開発用コンピューター上の IIS でアプリケーションが実行されると、アプリケーションは既定のアプリケーション プールの資格情報を使用して、データベースにアクセスします。 ただし、既定では、アプリケーション プールに、データベースを開くアクセス許可はありません。 つまり、そのアクセス許可を付与するスクリプトを実行する必要があります。 このセクションでは、そのスクリプトを作成して実行し、アプリケーションが IIS で実行されるときにデータベースを確実に開くことができるようにします。

テキスト エディターで、次の SQL コマンドを新しいファイルにコピーし、Grant.sql として保存します。

IF NOT EXISTS (SELECT name FROM sys.server_principals WHERE name = 'IIS APPPOOL\DefaultAppPool')
BEGIN
    CREATE LOGIN [IIS APPPOOL\DefaultAppPool] 
      FROM WINDOWS WITH DEFAULT_DATABASE=[master], 
      DEFAULT_LANGUAGE=[us_english]
END
GO
CREATE USER [ContosoUniversityUser] 
  FOR LOGIN [IIS APPPOOL\DefaultAppPool]
GO
EXEC sp_addrolemember 'db_owner', 'ContosoUniversityUser'
GO

Visual Studio で、Contoso University ソリューションを開きます。 このソリューション (プロジェクトの 1 つではありません) を右クリックし、[追加] を選択します。 [既存の項目] を選択し、Grant.sql を参照して開きます。

Note

このスクリプトは、SQL Server Express 2012 以降で、このチュートリアルで指定する Windows 10、Windows 8、または Windows 7 の IIS 設定を使用して動作するように設計されています。 別のバージョンの SQL Server または Windows を使用している場合、またはお使いのコンピューターで IIS を異なって設定している場合、このスクリプトの変更が必要になることがあります。 SQL Server スクリプトの詳細については、SQL Server オンライン ブックを参照してください。

Note

セキュリティに関する注意 このスクリプトは、実行時にデータベースにアクセスユーザーに db_owner アクセス許可を付与します。これは、運用環境で使用できます。 一部のシナリオでは、デプロイ時にのみ、完全なデータベース スキーマ更新アクセス許可を持つユーザーを指定し、実行時には、データの読み取りと書き込みのアクセス許可のみを持つ別のユーザーを指定することが必要な場合があります。 詳細については、このチュートリアルで後述する「Code First Migrations の自動 Web.config 変更を確認する」を参照してください。

アプリケーション データベースで許可スクリプトを実行する

データベースのデプロイでは dbDacFx プロバイダーが使用されるため、デプロイ中にメンバーシップ データベースで許可スクリプトを実行するように発行プロファイルを構成できます。 Code First Migrations のデプロイ中にスクリプトを実行することはできません。Code First Migrations は、アプリケーション データベースをデプロイする方法です。 つまり、このスクリプトは、アプリケーション データベースにデプロイする前に手動で実行する必要があります。

  1. Visual Studio で、先ほど作成した Grant.sql ファイルを開きます。

  2. [接続] を選択します。

    [接続] ボタン

  3. [サーバーへの接続] ダイアログ ボックスで、[サーバー名] として「.\SQLExpress」と入力します。 接続を選択します。

  4. データベース ドロップダウン リストで、[ContosoUniversity] を選択します。 [実行] を選択します。

    データベース のドロップダウン リストで、ContosoUniversity を選択します。[実行] を選択します。

これで、既定のアプリケーション プール ID に、アプリケーション データベースで、アプリケーションの実行時に Code First Migrations がデータベース テーブルを作成するための十分なアクセス許可が与えられます。

IIS に発行する

Visual Studio と Web 配置を使用して IIS にデプロイするには、次のようにいくつかの方法があります。

  • Visual Studio のワンクリック発行を使用する。
  • コマンド ラインから発行する。
  • 展開パッケージを作成し、IIS マネージャーを使用してインストールする。 このパッケージには、サイトを IIS にインストールするために必要なすべてのファイルとメタデータを含む .zip ファイルが含まれます。
  • 展開パッケージを作成し、コマンド ラインを使用してインストールする。

デプロイ タスクを自動化するように Visual Studio を設定するために前のチュートリアルで実行したプロセスは、これらのすべての方法に適用されます。 これらのチュートリアルでは、最初の 2 つの方法を使用します。 展開パッケージの詳細については、Visual Studio および ASP.NET の Web 配置コンテンツ マップの「Web 配置パッケージを作成してインストールして Web アプリケーションをデプロイする」を参照してください。

発行する前に、Visual Studio を管理者モードで実行していることを確認します。 タイトル バーに (管理者) が表示されない場合は、Visual Studio を閉じます。 Windows 8 (以降) の [スタート] ページ、または Windows 7 の [スタート] メニューで、Visual Studio アイコンを右クリックし、[管理者として実行] を選択します。 管理者モードは、ローカル コンピューター上の IIS に発行する場合にのみ必要です。

発行プロファイルを作成する

  1. ソリューション エクスプローラーで、[ContosoUniversity] プロジェクト (ContosoUniversity.DAL プロジェクトではありません) を右クリックします。 公開を選択します。 [発行] ページが表示されます。

  2. [新しいプロファイル] を選択します。 [発行先を選択] ダイアログ ボックスが表示されます。

  3. [IIS、FTP、その他] を選択します。[プロファイルの作成] を選択します。 発行ウィザードが表示されます。

    [Web の発行] ウィザードの [プロファイル] タブ

  4. [発行方法] ドロップダウン メニューから [Web 配置] を選択します。

  5. [サーバー] で、「localhost」と入力します。

  6. [サイト名] で、「Default Web Site/ContosoUniversity」と入力します。

  7. [宛先 URL] で、「http://localhost/ContosoUniversity」と入力します。

    [宛先 URL] 設定は必要ありません。 Visual Studio でアプリの配置が完了すると、既定のブラウザーでこの URL が自動的に開きます。 デプロイ後にブラウザーを自動的に開かないようにする場合は、このボックスを空白のままにします。

  8. [接続の検証] を選択して、設定が正しいことと、ローカル コンピューター上の IIS に接続できることを確認します。

    緑色のチェック マークは、接続が成功したことを示します。

    Web の発行ウィザードの [接続] タブ

  9. [次へ] を選択して、[設定] タブに進みます。

  10. [構成] ドロップダウン ボックスでは、デプロイするビルド構成を指定します。 これは、既定値の [リリース] に設定したままにします。 このチュートリアルでは、[デバッグ] ビルドをデプロイしません。

  11. [ファイル発行オプション] を展開します。 [App_Data フォルダーのファイルを除外する] をオンにします。

    テスト環境では、アプリケーションは、App_Data フォルダー内の .mdf ファイルではなく、ローカルの SQL Server Express インスタンス内に作成したデータベースにアクセスします。

  12. [発行中にプリコンパイルする][発行先の追加ファイルを削除する] のチェック ボックスはオフのままにします。

    [設定] タブの [ファイル発行オプション]

    プリコンパイルは、主に大規模なサイトに役立つオプションです。 これは、サイトの発行後に最初にページを要求する際の起動時間を短縮できます。

    これは最初のデプロイであり、発行先フォルダーにはまだファイルが存在しないため、追加のファイルを削除する必要はありません。

    Note

    同じサイトへの後続のデプロイに対して [発行先の追加ファイルを削除する] オンにする場合は、デプロイする前に必ずプレビュー機能を使用して、削除されるファイルを事前に確認してください。 想定される動作は、Web 配置によって、プロジェクトで削除したファイルが宛先サーバー上で削除されることです。 ただし、ソース フォルダーと宛先フォルダーの下のフォルダー構造全体が比較されます。また、一部のシナリオでは、Web 配置によって削除したくないファイルが削除される可能性があります。

    たとえば、サーバー上のサブフォルダーに Web アプリケーションがある場合、プロジェクトをルート フォルダーにデプロイすると、そのサブフォルダーは削除されます。 contoso.com のメイン サイト用のプロジェクトが 1 つあり、contoso.com/blog のブログ用の別のプロジェクトがあるとします。 ブログ アプリケーションはサブフォルダー内にあります。 メイン サイトをデプロイするときに [発行先の追加ファイルを削除する] をオンにすると、ブログ アプリケーションは削除されます。

    もう 1 つの例として、App_Data フォルダーが予期せず削除される場合があります。 SQL Server Compact などの特定のデータベースでは、データベース ファイルが App_Data フォルダーに格納されます。 最初のデプロイ後、後続のデプロイでデータベース ファイルのコピーを続けない場合は、[Web のパッケージ化/発行] タブで [App_Data を除外する] をオンにします。これを行った後、[発行先の追加ファイルを削除する] をオンにしている場合、次に発行するときに、データベース ファイルと App_Data フォルダー自体が削除されます。

メンバーシップ データベースのデプロイを構成する

次の手順は、ダイアログ ボックスの [データベース] セクションの DefaultConnection データベースに適用されます。

  1. [リモート接続文字列] ボックスに、新しい SQL Server Express メンバーシップ データベースを指す次の接続文字列を入力します。

    Data Source=.\SQLExpress;Initial Catalog=aspnet-ContosoUniversity;Integrated Security=True
    

    [実行時にこの接続文字列を使用する] がオンになっているため、デプロイ プロセスでは、デプロイされた Web.config ファイルにこの接続文字列を格納します。

    また、サーバー エクスプローラーから接続文字列を取得することもできます。 サーバー エクスプローラーで、[データ接続] を展開して <マシン名>\sqlexpress.aspnet-ContosoUniversity データベースを選択し、[プロパティ] ウィンドウから [接続文字列] の値をコピーします。 この接続文字列には、削除できる追加の設定 (Pooling=False) が 1 つ含まれます。

  2. [データベースの更新] を選択します。

    これにより、デプロイ時に、宛先データベースにデータベース スキーマが作成されます。 次の手順では、実行する必要がある追加のスクリプトを指定します。1 つは、既定のアプリケーション プールへのデータベース アクセスを許可するスクリプトで、もう 1 つはデータをデプロイするスクリプトです。

  3. [データベース更新の構成] を選択します。

  4. [データベース更新の構成] ダイアログ ボックスで、[SQL スクリプトの追加] を選択します。 先ほどソリューション フォルダーに保存した Grant.sql スクリプトに移動します。

  5. このプロセスを繰り返して、aspnet-data-dev.sql スクリプトを追加します。

    メンバーシップ データベースのデータベース更新を構成する

  6. [閉じる] を選択します。

アプリケーション データベースのデプロイを構成する

Visual Studio で Entity Framework の DbContext クラスが検出されると、[データベースの更新] チェック ボックスではなく [Code First Migrations の実行] チェック ボックスを含むエントリが [データベース] セクションに作成されます。 このチュートリアルの場合、そのチェック ボックスを使用して、Code First Migrations によるデプロイを指定します。

一部のシナリオでは、DbContext データベースを使用しているが、データのデプロイに Migratios ではなく dbDacFx プロバイダーを使用することが必要な場合があります。 その場合は、MSDN の ASP.NET Web 配置に関する FAQ の「Migratios を使用せずに Code First データベースをデプロイするにはどうすればいいですか?」を参照してください。

次の手順は、ダイアログ ボックスの [データベース] セクションの SchoolContext データベースに適用されます。

  1. [リモート接続文字列] ボックスに、新しい SQL Server Express アプリケーション データベースを指す次の接続文字列を入力します。

    Data Source=.\SQLExpress;Initial Catalog=ContosoUniversity;Integrated Security=True
    

    [実行時にこの接続文字列を使用する] がオンになっているため、デプロイ プロセスでは、デプロイされた Web.config ファイルにこの接続文字列を格納します。

    メンバーシップ データベースの接続文字列を取得した場合と同じ方法で、サーバー エクスプローラーからアプリケーション データベースの接続文字列を取得することもできます。

  2. [Code First Migrations の実行 (アプリケーションの起動時に実行)] を選択します。

    このオプションをオンにすると、デプロイ プロセスにより、MigrateDatabaseToLatestVersion 初期化子を指定するように、デプロイされた Web.config ファイルが構成されます。 この初期化子は、アプリケーションがデプロイ後に初めてデータベースにアクセスするときに、データベースを最新バージョンに自動的に更新します。

発行プロファイル変換を構成する

  1. [閉じる] を選択します。 変更を保存するかどうかを確認するメッセージが表示されたら、[はい] を選択します。

  2. ソリューション エクスプローラーで、[プロパティ][PublishProfiles] の順に展開します。

  3. CustomProfile.pubxml を右クリックし、その名前を Test.pubxml に変更します。

  4. Test.pubxml を右クリックします。 [構成変換の追加] を選択します。

    [構成変換の追加] メニュー

    Visual Studio によって、Web.Test.config 変換ファイルが作成されて開かれます。

  5. Web.Test.config 変換ファイルで、開始構成タグの直後に次のコードを挿入します。

    <appSettings>
        <add key="Environment" value="Test" xdt:Transform="SetAttributes" xdt:Locator="Match(key)"/>
    </appSettings>
    

    テスト発行プロファイルを使用すると、この変換によって、環境インジケーターが "Test" に設定されます。 デプロイされたサイトでは、H1 見出し "Contoso University" の後に "(Test)" と表示されます。

  6. ファイルを保存して閉じます。

  7. Web.Test.config ファイルを右クリックし、[変換のプレビュー] を選択して、コード化した変換によって期待される変更が生成されることを確認します。

    [Web.config のプレビュー] ウィンドウに、Web.Release.config 変換と Web.Test.config 変換の両方を適用した結果が表示されます。

デプロイ更新をプレビューする

  1. Web の発行ウィザードをもう一度開きます (ContosoUniversity プロジェクトを右クリックし、[発行][プレビュー] の順に選択します)。

  2. [プレビュー] ダイアログ ボックスで、[プレビューの開始] を選択して、コピーされるファイルの一覧を表示します。

    プレビューの発行

    また、[データベースのプレビュー] リンクを選択して、メンバーシップ データベースで実行されるスクリプトを確認することもできます (Code First Migrations によるデプロイの場合はスクリプトが実行されないため、アプリケーション データベースについてはプレビューするものはありません)。

  3. 公開を選択します。

    Visual Studio が管理者モードではない場合、アクセス許可に関するエラー メッセージが表示されることがあります。 その場合は、Visual Studio を閉じ、管理者モードで開いて、もう一度発行してみてください。

    Visual Studio が管理者モードの場合、[出力] ウィンドウに、ビルドと発行が成功したことが報告されます。

    Output_window_publish_Test

    発行プロファイルの [接続] タブで、[宛先 URL] に URL を入力した場合、ブラウザーによって、コンピューター上の IIS で実行されている Contoso University のホーム ページが自動的に開かれます。

テスト環境でテストする

環境インジケーターが "(Dev)" ではなく "(Test)" を示すことに注意してください。これは、環境変数の Web.config 変換が成功したことを示しています。

[講師] ページを実行して、Code First によってデータベースに講師のデータがシードされたことを確認します。 このページを選択した場合、読み込みに数分かかることがあります。これは、Code First によってデータベースを作成され、Seed メソッドが実行されるためです (ホーム ページでは、アプリケーションがまだデータベースへのアクセスを試みていないため、この操作は行われませんでした)。

[学生] タブを選択して、デプロイされたデータベースに学生が含まれていないことを確認します。

[学生] メニューから [学生の追加] を選択します。 学生を追加すると、その新しい学生が [学生] ページに表示されます。 これにより、データベースに正常に書き込むことができることが確認されます。

[課程] メニューから [単位の更新] を選択します。 [単位の更新] ページには、管理者アクセス許可が必要であるため、[ログイン] ページが表示されます。 前に作成した管理者アカウントの資格情報 ("admin" と "devpwd") を入力します。 [単位の更新] ページが表示されます。 これにより、前のチュートリアルで作成した管理者アカウントがテスト環境に正しくデプロイされたことが確認されます。

プレースホルダー ファイルのみを含む c:\inetpub\wwwroot\ContosoUniversity フォルダー内に ELMAH フォルダーがあることを確認します。

Code First Migrations の自動 Web.config 変更を確認する

C:\inetpub\wwwroot\ContosoUniversity で、デプロイされたアプリケーションの Web.config ファイルを開くと、デプロイ プロセスで、データベースを最新バージョンに自動的に更新するように Code First Migratios が構成された場所を確認できます。

デプロイされたアプリケーションの Web.config ファイルを C:\inetpub\wwwroot\ContosoUniversity で開き、デプロイ プロセスによって Code First Migrations が構成され、データベースが最新バージョンに自動的に更新された場所を確認します。

配置プロセスでは、Code First Migrations でデータベース スキーマの更新のみに使用される新しい接続文字列も作成されました。

Database_Publish 接続文字列

この接続文字列の追加により、データベース スキーマの更新用に 1 つのユーザー カウントを指定し、アプリケーション データへのアクセス用に別のユーザー アカウントを指定できます。 たとえば、db_owner ロールを Code First Migrations に割り当て、db_datawriter ロールを持つ db_datareader をアプリケーションに割り当てることができます。 これは、アプリケーション内の悪意のあるコードによってデータベース スキーマが変更されるのを防ぐ多層防御の一般的なパターンです (たとえば、悪意のあるコードによる変更は、SQL インジェクション攻撃が成功した場合に発生する可能性があります)。これらのチュートリアルでは、このパターンを使用しません。 このパターンをシナリオに実装するには、次の手順を実行します。

  1. Web の発行 ウィザードの [設定] タブで、完全なデータベース スキーマ更新アクセス許可を持つユーザーを指定する接続文字列を入力します。 [実行時にこの接続文字列を使用する] チェック ボックスをオフにします。 デプロイされた Web.config ファイルでは、これが接続文字列 DatabasePublish になります。

  2. 実行時にアプリケーションで使用する接続文字列の Web.config ファイル変換を作成します。

まとめ

これで、開発用コンピューター上の IIS にアプリケーションをデプロイし、そこでのテストが完了しました。

テストのホーム ページ

これにより、デプロイ プロセスによって、アプリケーションのコンテンツが適切な場所にコピーされたこと (デプロイしたくないファイルを除外)、およびデプロイ時に Web 配置によって、IIS が正しく構成されたことが確認されます。 次のチュートリアルでは、まだ実行されていないデプロイメント タスク (Elm ah フォルダーのフォルダー アクセス許可の設定) を見つけるもう 1 つのテストを実行します。

詳細

Visual Studio での IIS または IIS Express の実行については、次のリソースを参照してください。