文書番号: 436737 - 最終更新日: 2004年5月5日 - リビジョン: 3.1

[PRB] ASP.NET から SQL Server へ接続すると "ユーザー '<マシン名>\ASPNET' はログインできませんでした" というエラーが発生する

お知らせお使いのオペレーティング システムには適用しない情報が含まれている場合があります。
この記事は、以前は次の ID で公開されていました: JP436737
すべて展開する | すべて折りたたむ

現象

ASP.NET Web アプリケーションから SQL Server へ接続すると、以下のようなエラーが発生します。
ユーザー '<マシン名>\ASPNET' はログインできませんでした。

例外の詳細: System.Data.SqlClient.SqlException: ユーザー '<マシン名>\ASPNET' はログインできませんでした。

ソース エラー:
行 56: private void Button1_Click(object sender, System.EventArgs e)
行 57: {
行 58: sqlConnection1.Open();
行 59: }
行 60: }

スタック トレース:
[SqlException: ユーザー '<マシン名>\ASPNET' はログインできませんでした。]
System.Data.SqlClient.SqlConnection.Open()
WebApplication1.WebForm1.Button1_Click(Object sender, EventArgs e) in c:\inetpub\wwwroot\webapplication1\webform1.aspx.cs:58
System.Web.UI.WebControls.Button.OnClick(EventArgs e)
System.Web.UI.WebControls.Button.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument)
System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument)
System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData)
System.Web.UI.Page.ProcessRequestMain()

原因

本現象は、ASP.NET が使用するローカル アカウントが、SQL Server にログインするために必要なアクセス権を持っていないために発生しています。ASP.NET は、Web アプリケーション コードをワーカー プロセスの中で実行します。このプロセスは ASPNET という名前の権限の少ないローカル アカウントになります。
ASP.NET のベータ リリースでは、強力な権限を持つ System ローカル アカウントを使用していましたが、現在ではセキュリティの問題から、より権限の小さい ASPNET ローカル アカウントを使用しています。

解決方法

以下のいずれかの方法により、本現象を解決します。
これらの解決方法の詳細に関しましては、後述する [関連情報] をご参照ください。
  1. ASPNET ローカル アカウントに対して SQL Server への適切なログイン権限を与える
    [ローカル ユーザーとグループ] 管理コンソールなどを使用して、ASPNET ローカル アカウントに対して SQL Server への適切なログイン権限を与えます。
  2. ASP.NET アプリケーションの全ての要求に対して偽装する

    ASP.NET アプリケーションの Web.config ファイルに identity 要素を追加することにより、アプリケーションへの全ての要求に対して偽装することが可能です。以下の内容を Web.config ファイル内の /configuration/system.web 要素に追加します。
    web.config に以下の行を追加
    <identity impersonate="true" />
  3. SQL Server へのログインに、Windows 認証ではなく SQL Server 認証を使用する
    Windows 認証の代わりに、特定のログイン名とパスワードを指定する SQL Server 認証を使用します。

状況

この現象は仕様によるものです。

関連情報

306158? (http://support.microsoft.com/kb/306158/JA/ ) [INFO] ASP.NET アプリケーションに偽装を実装する
317012? (http://support.microsoft.com/kb/317012/JA/ ) [INFO] ASP.NET のプロセス ID と要求 ID
316989? (http://support.microsoft.com/kb/316989/JA/ )  [PRB] ASP.NET から SQL Server への信頼されたデータ接続を作成するとエラー メッセージ "ログインできませんでした" が表示される

この資料は以下の製品について記述したものです。
  • Microsoft Visual Studio .NET 2002 Professional Edition
  • Microsoft .NET Framework 1.1
キーワード:?
kbprb mdac msde odbc oledbconnection KB436737
"Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。"