ASP.Net使用System.Security.Principal模擬用戶
一、概述
在實際的項目開發(fā)中,我們可能會需要調用一些非托管程序,而有些非托管程序需要有更高的身份權限才能正確執(zhí)行。本文介紹了如何讓IIS承載的ASP.NET網站以特定的賬戶執(zhí)行,比如Administrator。
默認情況下禁用 ASP.NET 模擬。如果對某 ASP.NET 應用程序啟用了模擬,該應用程序將運行在標識上下文中,其訪問標記被 IIS 傳遞給 ASP.NET。
- 該標記可以是已通過身份驗證的用戶標記(如已登錄的 Windows 用戶的標記)【IIS上配置“集成Widows身份驗證”且不勾選“匿名訪問”的情況下】
- 該標記也可以是 IIS 為匿名用戶提供的標記(通常為 IUSR_MACHINENAME 標識)。 【IIS上配置勾選“匿名訪問”的情況下】

二、讀取被模擬用戶的標識
注意:可以使用以下代碼來確定線程作為哪個用戶執(zhí)行:
WindowsIdentity.GetCurrent().Name
三、模擬 IIS 驗證的帳戶或用戶
若要在收到 ASP.NET 應用程序中每個頁的每個請求時模擬 Microsoft Internet 信息服務 (IIS) 身份驗證用戶,必須在此應用程序的 Web.config 文件中包含 <identity> 標記,并將 impersonate 屬性設置為 true。例如:
<identity impersonate="true" />
四、為 ASP.NET 應用程序的所有請求模擬特定用戶
若要為 ASP.NET 應用程序的所有頁面上的所有請求模擬特定用戶,可以在該應用程序的 Web.config 文件的 <identity> 標記中指定 userName 和 password 屬性。例如:
<identity impersonate="true" userName="accountname" password="password" />
五、在代碼中模擬身份驗證用戶
若要僅在運行代碼的特定部分時模擬身份驗證用戶 (User.Identity),您可以使用以下代碼。此方法要求身份驗證用戶標識的類型為 WindowsIdentity。
WindowsImpersonationContext impersonationContext = ((WindowsIdentity)User.Identity).Impersonate(); //Insert your code that runs under the security context of the authenticating user here. impersonationContext.Undo();
六、在代碼中模擬特定用戶
若要僅在運行代碼的特定部分時模擬特定用戶,請使用以下代碼(使用Windows API):
<%@ Page Language="C#"%>
<%@ Import Namespace = "System.Web" %>
<%@ Import Namespace = "System.Web.Security" %>
<%@ Import Namespace = "System.Security.Principal" %>
<%@ Import Namespace = "System.Runtime.InteropServices" %>
<script runat=server>
public const int LOGON32_LOGON_INTERACTIVE = 2;
public const int LOGON32_PROVIDER_DEFAULT = 0;
WindowsImpersonationContext impersonationContext;
[DllImport("advapi32.dll")]
public static extern int LogonUserA(String lpszUserName,
String lpszDomain,
String lpszPassword,
int dwLogonType,
int dwLogonProvider,
ref IntPtr phToken);
[DllImport("advapi32.dll", CharSet=CharSet.Auto, SetLastError=true)]
public static extern int DuplicateToken(IntPtr hToken,
int impersonationLevel,
ref IntPtr hNewToken);
[DllImport("advapi32.dll", CharSet=CharSet.Auto, SetLastError=true)]
public static extern bool RevertToSelf();
[DllImport("kernel32.dll", CharSet=CharSet.Auto)]
public static extern bool CloseHandle(IntPtr handle);
public void Page_Load(Object s, EventArgs e)
{
if(impersonateValidUser("username", "domain", "password"))
{
//Insert your code that runs under the security context of a specific user here.
undoImpersonation();
}
else
{
//Your impersonation failed. Therefore, include a fail-safe mechanism here.
}
}
private bool impersonateValidUser(String userName, String domain, String password)
{
WindowsIdentity tempWindowsIdentity;
IntPtr token = IntPtr.Zero;
IntPtr tokenDuplicate = IntPtr.Zero;
if(RevertToSelf())
{
if(LogonUserA(userName, domain, password, LOGON32_LOGON_INTERACTIVE,
LOGON32_PROVIDER_DEFAULT, ref token) != 0)
{
if(DuplicateToken(token, 2, ref tokenDuplicate) != 0)
{
tempWindowsIdentity = new WindowsIdentity(tokenDuplicate);
impersonationContext = tempWindowsIdentity.Impersonate();
if (impersonationContext != null)
{
CloseHandle(token);
CloseHandle(tokenDuplicate);
return true;
}
}
}
}
if(token!= IntPtr.Zero)
CloseHandle(token);
if(tokenDuplicate!=IntPtr.Zero)
CloseHandle(tokenDuplicate);
return false;
}
private void undoImpersonation()
{
impersonationContext.Undo();
}到此這篇關于ASP.Net使用System.Security.Principal模擬用戶的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
ASP.NET MVC4中使用Html.DropDownListFor的方法示例
這篇文章主要介紹了ASP.NET MVC4中使用Html.DropDownListFor的方法,結合實例形式分析了控制器數據源及Html.DropDownListFor顯示操作的相關技巧,需要的朋友可以參考下2016-08-08
ASP.NET Gridview 中使用checkbox刪除的2種方法實例分享
ASP.NET Gridview 中使用checkbox刪除的2種方法實例分享,需要的朋友可以參考一下2013-06-06

