Kha*_*ied 1 .net c# windows permissions
假如我构建了一个从网络文件夹中读取文件的Windows应用程序.网络折叠限制只能访问一个用户"fooUser".该应用程序安装在网络上的多台计算机上.
我需要用"fooUser"替换当前用户,以便能够通过代码访问网络文件夹中的文件.
这是一个非常简单的冒充计划,让你成为一个人在一个镜头期间(授予你相应的证书.)
这个课将为你做所有繁重的工作....
public class Impersonator : IDisposable
{
const int LOGON32_PROVIDER_DEFAULT = 0;
const int LOGON32_LOGON_INTERACTIVE = 2;
[DllImport("advapi32.dll", SetLastError = true)]
public static extern bool LogonUser(String lpszUsername, String lpszDomain, String lpszPassword, int dwLogonType, int dwLogonProvider, ref IntPtr phToken);
[DllImport("kernel32.dll", CharSet = CharSet.Auto)]
public extern static bool CloseHandle(IntPtr handle);
private IntPtr token = IntPtr.Zero;
private WindowsImpersonationContext impersonated;
private readonly string _ErrMsg = "";
public bool IsImpersonating
{
get { return (token != IntPtr.Zero) && (impersonated != null); }
}
public string ErrMsg
{
get { return _ErrMsg; }
}
[PermissionSetAttribute(SecurityAction.Demand, Name = "FullTrust")]
public Impersonator(string userName, string password, string domain)
{
StopImpersonating();
bool loggedOn = LogonUser(userName, domain, password, LOGON32_LOGON_INTERACTIVE, LOGON32_PROVIDER_DEFAULT, ref token);
if (!loggedOn)
{
_ErrMsg = new System.ComponentModel.Win32Exception().Message;
return;
}
WindowsIdentity identity = new WindowsIdentity(token);
impersonated = identity.Impersonate();
}
private void StopImpersonating()
{
if (impersonated != null)
{
impersonated.Undo();
impersonated = null;
}
if (token != IntPtr.Zero)
{
CloseHandle(token);
token = IntPtr.Zero;
}
}
public void Dispose()
{
StopImpersonating();
}
}
Run Code Online (Sandbox Code Playgroud)
你可以像这样使用它;
using (Impersonator = new Impersonator(yourName,yourPassword,yourDomain))
{
// Read files from network drives.
// Other activities....
}
Run Code Online (Sandbox Code Playgroud)
将模仿者放置在"使用"块中,或者在完成模拟任务时将其处置,或系统将继续无限期冒充,这将导致各种问题,这一点非常重要.