配置が必要なファイルを決定する (VB)
開発環境から運用環境にデプロイする必要があるファイルは、ASP.NET アプリケーションが Web サイト モデルと Web アプリケーション モデルのどちらを使用してビルドされたかによって異なります。ただし、その違いは部分的です。 これら 2 つのプロジェクト モデルの詳細と、プロジェクト モデルがデプロイにどのように影響するかについて説明します。
はじめに
ASP.NET Web アプリケーションをデプロイするには、開発環境から運用環境へ ASP.NET に関連するファイルをコピーする必要があります。 ASP.NET 関連のファイルには、ASP.NET Web ページ マークアップおよび、コード、クライアント側、サーバー側のサポート ファイルが含まれます。 クライアント側のサポート ファイルとは、Web ページが参照し、ブラウザーに直接送信するファイル (画像、CSS ファイル、JavaScript ファイルなど) です。 サーバー側のサポート ファイルには、サーバー側で要求を処理するために使用するものが含まれます。 これには、構成ファイル、Web サービス、クラス ファイル、型指定されたデータセット、LINQ to SQL ファイルなどが含まれます。
一般に、すべてのクライアント側サポート ファイルを開発環境から運用環境にコピーする必要がありますが、コピーされるサーバー側のサポート ファイルは、ユーザーがサーバー側コードをアセンブリ (.dll
ファイル) に明示的にコンパイルするか、これらのアセンブリを自動生成するかによって異なります。 このチュートリアルでは、コードをアセンブリに明示的にコンパイルする場合と、このコンパイル手順を自動的に実行する場合の、デプロイする必要があるファイルに違いに焦点を当てます。
明示的なコンパイルと自動コンパイル
ASP.NET Web ページは、宣言型マークアップとソース コードに分かれています。 宣言型マークアップ部分には、HTML、Web コントロール、およびデータ バインド構文が含まれます。コード部分には、Visual Basic または C# コードで記述されたイベント ハンドラーが含まれています。 マークアップ部分とコード部分は通常、別々のファイルに分かれます。WebPage.aspx
には宣言型マークアップが含まれているのに対し、WebPage.aspx.vb
はコードを格納します。
Text プロパティがページの読み込み時に現在の日時に設定される Label コントロールを含む、Clock.aspx
という名前の ASP.NET ページについて考えてみましょう。 宣言型マークアップ部分 (Clock.aspx
) には Label Web コントロールのマークアップ (<asp:Label runat="server" id="TimeLabel" />
) が含まれる一方、コード部分 (Clock.aspx.vb
) には次の コードを含む Page_Load
イベント ハンドラーがあります。
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
TimeLabel.Text = "The time at the beep is: " & DateTime.Now.ToString()
End Sub
ASP.NET エンジンがこのページの要求を処理するには、まずページのコード部分 (WebPage
.aspx.vb
ファイル) をコンパイルする必要があります。 このコンパイルは、明示的または自動的に行うことができます。
コンパイルを明示的に行う場合、アプリケーションのソース コード全体が、アプリケーションの Bin
ディレクトリにある 1 つ以上のアセンブリ (.dll
ファイル) にコンパイルされます。 コンパイルを自動的に行う場合、生成される自動生成アセンブリは既定で、%WINDOWS%\Microsoft.NET\Framework\<version>
にある Temporary ASP.NET Files
フォルダーに配置されます。ただし、この場所は、Web.config
の <コンパイル> 要素を介して構成できます。 明示的なコンパイルでは、ASP.NET アプリケーションのコードをアセンブリにコンパイルするために何らかのアクションを実行する必要があります。この手順は、デプロイ前に行われます。 自動コンパイルでは、リソースが最初にアクセスされるときに、Web サーバーでコンパイル プロセスが実行されます。
使用するコンパイル モデルに関係なく、すべての ASP.NET ページのマークアップ部分 (WebPage.aspx
ファイル) を運用環境にコピーする必要があります。 明示的なコンパイルでは、Bin
フォルダー内のアセンブリをコピーする必要がありますが、ASP.NET ページのコード部分 (WebPage.aspx.vb
ファイル) をコピーする必要はありません。 自動コンパイルでは、コードが存在し、ページにアクセスしたときに自動的にコンパイルできるように、コード部分のファイルをコピーする必要があります。 各 ASP.NET Web ページのマークアップ部分には、ページに関連付けられているコードが既に明示的にコンパイルされているかどうか、または自動的にコンパイルする必要があるかどうかを示す属性を持つ @Page
ディレクティブが含まれています。 その結果、運用環境はどちらのコンパイル モデルもシームレスに操作できるため、明示的または自動コンパイルが使用されることを示すために特別な構成設定を適用する必要はありません。
表 1 は、明示的なコンパイルと自動コンパイルを使用する場合にデプロイするさまざまなファイルをまとめたものです。 使用するコンパイル モデルに関係なく、Bin
フォルダーが存在する場合は、常にアセンブリをそのフォルダーに配置する必要があることに注意してください。 Bin
フォルダーには、明示的なコンパイル モデルを使用する場合にコンパイルされたソース コードを含む、Web アプリケーションに固有のアセンブリが含まれています。 Bin
ディレクトリには、他のプロジェクトのアセンブリや、ユーザーが使用する可能性があるオープンソースまたはサードパーティ製のアセンブリも含まれており、これらは運用サーバー上に配置する必要があります。 そのため、一般的な経験則としては、デプロイ時に運用環境まで Bin
フォルダーをコピーします。 (自動コンパイル モデルを使用していて、外部アセンブリを使用していない場合は、Bin
ディレクトリはありませんが、問題ありません)
コンパイル モデル | マークアップ部分ファイルを展開しますか? | ソース コード ファイルをデプロイしますか? | Bin ディレクトリにアセンブリを配置しますか? |
---|---|---|---|
明示的なコンパイル | はい | いいえ | はい |
自動コンパイル | はい | はい | はい (存在する場合) |
表 1: デプロイするファイルは、使用するコンパイル モデルによって異なります。
思い出してみましょう
どのようなコンパイル方法を使用するかは、Visual Studio で ASP.NET アプリケーションを管理する方法によってある程度異なります。 2000 年の .NET 開始以来、Visual Studio .NET 2002、Visual Studio .NET 2003、Visual Studio 2005、Visual Studio 2008 という 4 バージョンがあります。 Visual Studio .NET 2002 と 2003 では、Web アプリケーション プロジェクト モデルを使用して ASP.NET アプリケーションを管理していました。 Web アプリケーション プロジェクト モデルの主な機能は次のとおりです。
- プロジェクトを構成するファイルは、単一のプロジェクト ファイルで定義されます。 プロジェクト ファイルで定義されていないファイルは、Visual Studio では Web アプリケーションの一部とは見なされません。
- 明示的なコンパイルを使用します。 プロジェクトをビルドすると、プロジェクト内のコード ファイルが、
Bin
フォルダーに配置された 1 つのアセンブリにコンパイルされます。
Microsoft が Visual Studio 2005 をリリースした時点で、Web アプリケーション プロジェクト モデルのサポートが削除され、Web サイト プロジェクト モデルに置き換えられました。 Web サイト プロジェクト モデルは、次のように Web アプリケーション プロジェクト モデルと差別化されました。
- プロジェクトのファイルを単一のプロジェクト ファイルで記述するのではなく、ファイル システムを使用します。 つまり、Web アプリケーション フォルダー (またはサブフォルダー) 内のすべてのファイルは、プロジェクトの一部と見なされます。
- Visual Studio でプロジェクトをビルドしても、
Bin
ディレクトリにアセンブリは作成されません。 代わりに、Web サイト プロジェクトをビルドすると、コンパイル時エラーが報告されます。 - 自動コンパイルのサポート。 Web サイト プロジェクトは通常、マークアップとソース コードを運用環境にコピーしてデプロイされますが、コードは事前コンパイル (明示的なコンパイル) することができます。
Microsoft は、Visual Studio 2005 Service Pack 1 をリリースしたときに Web アプリケーション プロジェクト モデルを復活させました。 ただし、Visual Web Developer は引き続き Web サイト プロジェクト モデルのみをサポートしています。 良いニュースは、この制限が Visual Web Developer 2008 Service Pack 1 では削除されたことです。 現在、Web アプリケーション プロジェクト モデルまたは Web サイト プロジェクト モデルを使用して、Visual Studio (および Visual Web Developer) で ASP.NET アプリケーションを作成できます。 どちらのモデルにも長所と短所があります。 2 つのモデルの比較については、「Web アプリケーション プロジェクトの概要: Web サイト プロジェクトと Web アプリケーション プロジェクトの比較」を参照した上で、状況に最適なプロジェクト モデルを決定してください。
サンプル Web アプリケーションの探索
このチュートリアルのダウンロードには、Book Reviewsという ASP.NET アプリケーションが含まれています。 この Web サイトは、誰かがブック レビューをオンライン コミュニティと共有するために作成したであろう、趣味の Web サイトを模倣しています。 この ASP.NET Web アプリケーションは非常にシンプルで、次のリソースで構成されています。
Web.config
- アプリケーションの構成ファイル。マスター ページ (
Site.master
)。7 つの別々の ASP.NET ページ:
~/
Default.aspx
- サイトのホームページ。~/
About.aspx
- [このサイトについて] ページ。~/
Fiction/Default.aspx
- レビューした小説の一覧を示すページ。- ~/
Fiction/Blaze.aspx
- リチャード・バックマンの小説『ブレイズ』のレビュー。
- ~/
~/
Tech/Default.aspx
- レビューした技術書の一覧を示すページ。- ~/
Tech/CYOW.aspx
- 『独自の Web サイトの作成』のレビュー。 - ~/
Tech/TYASP35.aspx
- 『24 時間 で ASP.NET 3.5 を独学』のレビュー。
- ~/
Styles
フォルダー内の 3 つの別々の CSS ファイル。4 つの画像ファイル - Powered by ASP.NET ロゴと、3 冊のレビューした書籍の画像はすべて
Images
フォルダー内にあります。Web.sitemap
ファイル。サイト マップを定義し、ルート ディレクトリ、Fiction
、Tech
フォルダーのDefault.aspx
ページでメニューを表示するために使用します。基底
Page
クラスを定義するBasePage.vb
という名前のクラス ファイル。 このクラスは、サイト マップ内のページの位置に基づいてTitle
プロパティを自動的に設定し、Page
クラスの機能を拡張します。 簡単に言うと、(System.Web.UI.Page
ではなく)BasePage
を拡張するASP.NET 分離コード クラスのタイトルは、サイト マップでの位置に応じた値に設定されます。 たとえば、~/Tech/CYOW.aspx
ページを表示する場合、タイトルは "ホーム: テクノロジ: 独自の Web サイトの作成" に設定されます。
図 1 は、ブラウザーで表示された Book Reviews Web サイトのスクリーン ショットを示しています。 ここでは ~/Tech/TYASP35.aspx のページが表示されます。このページでは、『24 時間 で ASP.NET 3.5 を独学』をレビューしています。 ページの上部と左側の列のメニューにまたがる階層リンクは、Web.sitemap
で定義されているサイト マップ構造に基づいています。 右上隅の画像は、Images
フォルダー内にある表紙画像の 1 つです。 Web サイトの外観は、Styles
フォルダー内 の CSS で記述したカスケード スタイル シート ルールを使用して定義され、包括的なページ レイアウトはマスター ページ (Site.master
) で定義されます。
図 1: Book Reviews Web サイトでは、さまざまなタイトルに関するレビューが表示されます (クリックするとフルサイズの画像を表示します)。
このアプリケーションはデータベースを使用しません。各レビューは、アプリケーションで個別の Web ページとして実装されます。 このチュートリアル (および次のいくつかのチュートリアル) では、データベースを持たない Web アプリケーションのデプロイについて説明します。 ただし、今後のチュートリアルでは、レビュー、閲覧者コメント、およびその他の情報をデータベース内に格納するようにこのアプリケーションを強化し、データ駆動型 Web アプリケーションを正しくデプロイするために必要な手順について説明します。
Note
これらのチュートリアルでは、Web ホスト プロバイダーを使用して ASP.NET アプリケーションをホストすることに重点を置き、ASP.NET のサイト マップ システムや、ベース Page クラスの使用などの補助的なトピックは扱いません。 これらのテクノロジの詳細と、チュートリアル全体で取り上げるその他のトピックの背景については、各チュートリアルの最後にある「追加情報」セクションを参照してください。
このチュートリアルのダウンロードには、Web アプリケーションの 2 つのコピーがあり、それぞれが異なる Visual Studio プロジェクトの種類として実装されています (BookReviewsWAP、Web アプリケーション プロジェクト、および Web サイト プロジェクト BookReviewsWSP)。 どちらのプロジェクトも Visual Web Developer 2008 SP1 で作成され、ASP.NET 3.5 SP1 を使用しています。 これらのプロジェクトを操作するには、まずコンテンツをデスクトップに解凍します。 Web アプリケーション プロジェクト (BookReviewsWAP) を開くには、BookReviewsWAP
フォルダーに移動し、ソリューション ファイル BookReviewsWAP.sln
をダブルクリックします。 Web サイト プロジェクト (BookReviewsWSP) を開くには、Visual Studio を起動した後、[ファイル] メニューの [Web サイトを開く] オプションを選択し、デスクトップ上の BookReviewsWSP
フォルダーを参照して [OK] をクリックします。
このチュートリアルの残りの 2 つのセクションでは、アプリケーションのデプロイ時に運用環境にコピーする必要があるファイルを確認します。 次の 2 つのチュートリアル (FTP を使用したサイトのデプロイと Visual Studio を使用したサイトのデプロイ) では、これらのファイルを Web ホスト プロバイダーにコピーする複数の方法について説明します。
Web アプリケーション プロジェクト用に配置するファイルを判断する
Web アプリケーション プロジェクト モデルでは、明示的なコンパイルを使用します。プロジェクトのソース コードは、アプリケーションをビルドするたびに 1 つのアセンブリにコンパイルされます。 このコンパイルには、ASP.NET ページの分離コード ファイル (~/Default.aspx.vb
、~/About.aspx.vb
など) と BasePage.vb
クラスが含まれます。 結果のアセンブリには BookReviewsWAP.dll
という名前が付けられ、アプリケーションの Bin
ディレクトリに配置されます。
図 2 は、Book Reviews Web アプリケーション プロジェクトを構成するファイルを示しています。
図 2: ソリューション エクスプローラーが、Web アプリケーション プロジェクトを構成するファイルを一覧表示しています
Note
図 2 に示すように、Visual Basic Web アプリケーション プロジェクトのソリューション エクスプローラーには、ASP.NET ページの分離コード ファイルは表示されません。 ページの分離コード クラスを表示するには、ソリューション エクスプローラーでページを右クリックし、[コードの表示] を選択します。
Web アプリケーション プロジェクト モデルを使用して開発された ASP.NET アプリケーションをデプロイするには、まず、最新のソース コードをアセンブリに明示的にコンパイルするようにアプリケーションをビルドします。 次に、以下のファイルを運用環境にコピーします。
- ~/
Default.aspx
、~/About.aspx
など、すべての ASP.NET ページの宣言型マークアップを含むファイル。 また、すべてのマスター ページとユーザー コントロールの宣言型マークアップをコピーします。 Bin
フォルダー内のアセンブリ (.dll
ファイル)。 プログラム データベース ファイル (.pdb
) またはBin
ディレクトリ内にある XML ファイルをコピーする必要はありません。
ASP.NET ページのソース コード ファイルを運用環境にコピーする必要も、BasePage.vb
クラス ファイルをコピーする必要もありません。
Note
図 2 に示すように、BasePage
クラスはプロジェクト内のクラス ファイルとして実装され、HelperClasses
という名前のフォルダーに配置されます。 プロジェクトがコンパイルされると、BasePage.vb
ファイル内のコードが、ASP.NET ページの分離コード クラスと共に 1 つのアセンブリ BookReviewsWAP.dll
にコンパイルされます。 ASP.NET には、App_Code
という、Web サイト プロジェクトのクラス ファイルを保持するように設計された特別なフォルダーがあります。 App_Code
フォルダー内のコードは自動的にコンパイルされるため、Web アプリケーション プロジェクトでは使用しないでください。 代わりに、アプリケーションのクラス ファイルを、HelperClasses
、Classes
または同様の名前を持つ通常のフォルダーに配置します。 または、クラス ファイルを別のクラス ライブラリ プロジェクトに配置することもできます。
ASP.NET 関連マークアップ ファイルのコピーと Bin
フォルダー内のアセンブリに加え、クライアント側のサポート ファイル (画像、CSS ファイルなど) と、他のサーバー側サポート ファイル (Web.config
、Web.sitemap
など) をコピーする必要があります。 明示的コンパイルと自動コンパイルのどちらを使用するかに関係なく、これらのクライアント側およびサーバー側のサポート ファイルを運用環境にコピーする必要があります。
Web サイト プロジェクト ファイル用に配置するファイルを判断する
Web サイト プロジェクト モデルでは、自動コンパイルがサポートされています。これは Web アプリケーション プロジェクト モデルを使用する場合には使用できない機能です。 明示的なコンパイルでは、プロジェクトのソース コードをアセンブリにコンパイルし、そのアセンブリを運用環境にコピーする必要があります。 一方、自動コンパイルでは、ソース コードを運用環境にコピーするだけで済みます。必要に応じてランタイムによってオンデマンドでコンパイルされます。
Visual Studio の [ビルド] メニュー オプションは、Web アプリケーション プロジェクトと Web サイト プロジェクトの両方にあります。 Web アプリケーション プロジェクトをビルドすると、プロジェクトのソース コードが Bin
ディレクトリ内の 1 つのアセンブリにコンパイルされます。Web サイト プロジェクトをビルドすると、コンパイル時のエラーがチェックされますが、アセンブリは作成されません。 Web サイト プロジェクト モデルを使用して開発された ASP.NET アプリケーションをデプロイするのに必要なことは、適切なファイルを運用環境にコピーするだけですが、最初にプロジェクトをビルドしてコンパイル時エラーが発生しないことを確認するのをお勧めします。
図 3 は、Book Reviews Web サイト プロジェクトを構成するファイルを示しています。
図 3: ソリューション エクスプローラーに Web サイト プロジェクトを構成するファイルが一覧表示されます
Web サイト プロジェクトをデプロイするには、運用環境にすべての ASP.NET 関連ファイルをコピーする必要があります。これには、ASP.NET ページ、マスター ページ、ユーザー コントロールのマークアップ ページとそのコード ファイルが含まれます。 また、BasePage.vb
などのクラス ファイルをコピーする必要があります。 BasePage.vb
ファイルは、Web サイト プロジェクトで使用される特別なクラス ファイル用 ASP.NET フォルダーである App_Code
フォルダーに配置されていることに注意してください。 特別なフォルダーは運用環境でも作成する必要があります。開発環境の App_Code
フォルダー内のクラス ファイルを App_Code
運用環境のフォルダーにコピーする必要があります。
ASP.NET マークアップとソース コード ファイルをコピーするだけでなく、クライアント側のサポート ファイル (画像、CSS ファイル) と、他のサーバー側のサポート ファイル (Web.config
、Web.sitemap
) をコピーする必要もあります。
Note
Web サイト プロジェクトでは、明示的なコンパイルを使用することもできます。 今後のチュートリアルでは、Web サイト プロジェクトを明示的にコンパイルする方法について説明します。
まとめ
ASP.NET アプリケーションをデプロイするには、開発環境から運用環境に必要なファイルをコピーする必要があります。 同期する必要があるファイルの正確なセットは、ASP.NET アプリケーションのコードを明示的にコンパイルするか、自動的にコンパイルするかによって異なります。 使用するコンパイル戦略は、Visual Studio ASP.NET アプリケーションを管理するのに、Web アプリケーション プロジェクト モデルと Web サイト プロジェクト モデルのどちらを使用するように構成されているかによって影響を受けます。
Web アプリケーション プロジェクト モデルでは、明示的なコンパイルが使用され、プロジェクトのコードが Bin
フォルダー内の 1 つのアセンブリにコンパイルされます。 アプリケーションをデプロイするときは、ASP.NET ページのマークアップ部分と Bin
フォルダーの内容を運用環境にプッシュする必要があります。アプリケーション内のソース コード (コード ファイルや分離コード クラスなど) を運用環境にコピーする必要はありません。
Web サイト プロジェクト モデルでは既定で自動コンパイルが使用されますが、今後のチュートリアルで説明するように、Web サイト プロジェクトを明示的にコンパイルすることもできます。 自動コンパイルを使用する ASP.NET アプリケーションをデプロイするには、マークアップ部分およびソース コードを運用環境にコピーする必要があります。 コードは、初めて要求されたときに、運用環境で自動的にコンパイルされます。
開発環境と運用環境の間で同期する必要があるファイルを確認したので、Book Reviews アプリケーションを Web ホスト プロバイダーにデプロイする準備ができました。
プログラミングに満足!
もっと読む
この記事で説明したトピックの詳細については、次のリソースを参照してください。