0

まず、これが重複していることをお詫びしますが、同様の問題はどこにも見つかりませんでした。

asp.net の偽装機能を使用して、ネットワーク ディレクトリにあるファイルを取得しようとしている状況です。web.config でユーザーを指定すると、正常に動作します。

<identity impersonate="true" userName="contoso\Jane" password="********" />

ただし、以下を使用しようとすると、サイトにログインするように求めるプロンプトが表示され、正常にログインできません。

<identity impersonate="true"/>

後者の例についての私の理解では、現在ページを表示しているユーザーの Windows 資格情報を (Windows 認証を介して) 偽装しようとするということです。これは正しくありませんか?

アプリの他の領域で Windows 認証が正しく機能していることに注意してください。

ありがとう

編集

また、これはII6で実行されていることにも言及する必要があります...そして、構成の問題のように「感じる」だけです...

4

1 に答える 1

0

別の方法で、Impersonate.cs クラスを追加し、ユーザー、パスワード、およびドメインが必要です。

Imperosnate.cs :

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web.Security;
using System.Security.Principal;
using System.Runtime.InteropServices;
using System.IO;
using System.Text;

using System.Web;

namespace [YourProgramName]  //You must change it
{
    public class Impersonate
    {

        [DllImport("advapi32.dll", SetLastError = true)]
        private static extern int LogonUser(string lpszUsername, string lpszDomain, string lpszPassword,
                                            int dwLogonType, int dwLogonProvider, out int phToken);

        [DllImport("kernel32.dll")]
        private static extern int FormatMessage(int dwFlags, string lpSource, int dwMessageId, int dwLanguageId,
                                                StringBuilder lpBuffer, int nSize, string[] Arguments);


        private const int LOGON32_LOGON_NETWORK_CLEARTEXT = 8;
        private const int LOGON32_PROVIDER_DEFAULT = 0;
        private const int FORMAT_MESSAGE_FROM_SYSTEM = 0x1000;

        private static WindowsImpersonationContext winImpersonationContext = null;

        public static void ImpersonateUser(string domain, string userName, string password)
        {

            //Benutzer einloggen
            int userToken = 0;

            bool loggedOn = (LogonUser(userName, domain, password, LOGON32_LOGON_NETWORK_CLEARTEXT,
                                        LOGON32_PROVIDER_DEFAULT, out userToken) != 0);

            if (loggedOn == false)
            {
                int apiError = Marshal.GetLastWin32Error();
                StringBuilder errorMessage = new StringBuilder(1024);
                FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM, null, apiError, 0, errorMessage, 1024, null);
                throw new Exception(errorMessage.ToString());
            }

            WindowsIdentity identity = new WindowsIdentity((IntPtr)userToken);
            winImpersonationContext = identity.Impersonate();

        }

        public static void UndoImpersonation()
        {
            if (winImpersonationContext != null)
            {
                winImpersonationContext.Undo();
            }
        }

    }
}

あなたのプログラムでそれを使用してください:

string Admin = Properties.Settings.Default.Admin;
        string AdminPassword = Properties.Settings.Default.AdminPassword;
        string Domain = Properties.Settings.Default.Domain;

        Impersonate.ImpersonateUser(Domain , Admin , AdminPassword);

                                //Your Code as the new User


                      Impersonate.UndoImpersonation();

それがあなたが検索したものであることを願っています^^

于 2012-07-24T08:10:56.730 に答える