ASP.NET模拟其他用户进行关机

ASP.NET模拟其他用户进行关机:
using System;
using System.Collections.Generic;
using System.Text;
using System.Security.Principal;
using System.Runtime.InteropServices;

public class Impersonate
{
    
#region 模拟
    
private WindowsImpersonationContext impersonationContext;

    
private const int LOGON32_LOGON_INTERACTIVE = 2;
    
private const int LOGON32_PROVIDER_DEFAULT = 0;

    [DllImport(
"advapi32.dll", CharSet = CharSet.Auto)]
    
private static extern int LogonUser(String lpszUserName, String lpszDomain, String lpszPassword, 
                  int dwLogonType, int dwLogonProvider, ref IntPtr phToken);

    [DllImport(
"advapi32.dll", CharSet = System.Runtime.InteropServices.CharSet.Auto, SetLastError = true)]
    
private extern static int DuplicateToken(IntPtr hToken, int impersonationLevel, ref IntPtr hNewToken);

    [DllImport(
"advapi32.dll", CharSet = CharSet.Auto, SetLastError = true)]
    
private static extern bool RevertToSelf();

    [DllImport(
"kernel32.dll", CharSet = CharSet.Auto)]
    
private extern static bool CloseHandle(IntPtr handle);

    
/// <summary>
    
/// 模拟一个用户
    
/// </summary>
    
/// <param name="userName">用户名</param>
    
/// <param name="password">密码</param>
    
/// <param name="domain">域名/计算机名</param>
    
/// <returns>true 模拟成功,false 模拟失败</returns>
    public bool ImpersonateUser(string userName, string password, string domain)
    {
        WindowsIdentity wi;
        IntPtr token 
= IntPtr.Zero;
        IntPtr tokenDuplicate 
= IntPtr.Zero;
        
if (RevertToSelf())
        {
            
if (LogonUser(userName, domain, password, 
                        LOGON32_LOGON_INTERACTIVE, LOGON32_PROVIDER_DEFAULT, 
ref token) != 0)
            {
                
if (DuplicateToken(token, 2ref tokenDuplicate) != 0)
                {
                    wi 
= new WindowsIdentity(tokenDuplicate);
                    impersonationContext 
= wi.Impersonate();
                    
if (impersonationContext != null)
                    {
                        CloseHandle(tokenDuplicate);
                        CloseHandle(token);
                        
return true;
                    }
                    
else
                    {
                        
if (tokenDuplicate != IntPtr.Zero) CloseHandle(tokenDuplicate);
                        
if (token != IntPtr.Zero) CloseHandle(token);
                        
return false;
                    }
                }
                
else
                {
                    
if (token != IntPtr.Zero) CloseHandle(token);
                    
return false;
                }
            }
            
else
                
return false;
        }
        
else
            
return false;
    }

    
/// <summary>
    
/// 取消模拟
    
/// </summary>
    public void UndoImpersonation()
    {
        impersonationContext.Undo();
    }
    
#endregion

    
#region 关机
    [StructLayout(LayoutKind.Sequential, Pack 
= 1)]
    
private struct TokPriv1Luid
    {
        
public int Count;
        
public long Luid;
        
public int Attr;
    }

    [DllImport(
"kernel32.dll", ExactSpelling = true)]
    
private static extern IntPtr GetCurrentThread();

    [DllImport(
"advapi32.dll", ExactSpelling = true, SetLastError = true)]
    
private static extern bool OpenThreadToken(IntPtr h, int acc, bool openAsSelf, ref IntPtr phtok);

    [DllImport(
"advapi32.dll", SetLastError = true)]
    
private static extern bool LookupPrivilegeValue(string host, string name, ref long pluid);

    [DllImport(
"advapi32.dll", ExactSpelling = true, SetLastError = true)]
    
private static extern bool AdjustTokenPrivileges(IntPtr htok, bool disall, ref TokPriv1Luid newst, 
                 int len, IntPtr prev, IntPtr relen);

    [DllImport(
"user32.dll", ExactSpelling = true, SetLastError = true)]
    
private static extern bool ExitWindowsEx(int flg, int rea);

    [DllImport(
"advapi32.dll")]
    
private static extern bool InitiateSystemShutdown(string Machinename, string Message, 
                  long Timeout, bool ForceAppsClosed, bool RebootAfterShutdown);

    
private const int SE_PRIVILEGE_ENABLED = 0x00000002;
    
private const int TOKEN_QUERY = 0x00000008;
    
private const int TOKEN_ADJUST_PRIVILEGES = 0x00000020;
    
private const string SE_SHUTDOWN_NAME = "SeShutdownPrivilege";
    
private const int EWX_LOGOFF = 0x00000000;
    
private const int EWX_SHUTDOWN = 0x00000001;
    
private const int EWX_REBOOT = 0x00000002;
    
private const int EWX_FORCE = 0x00000004;
    
private const int EWX_POWEROFF = 0x00000008;
    
private const int EWX_FORCEIFHUNG = 0x00000010;

    
/// <summary>
    
/// 关机
    
/// </summary>
    
/// <returns></returns>
    public bool ShutDown()
    {
        
bool result;
        TokPriv1Luid tp;
        
//注意:这里用的是GetCurrentThread,而不是GetCurrentProcess
        IntPtr hproc = GetCurrentThread();
        IntPtr htok 
= IntPtr.Zero;
        
//注意:这里用的是OpenThreadToken(打开线程令牌),而不是OpenProcessToken(打开进程令牌)
        result = OpenThreadToken(hproc, TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, 
                           trueref htok);
        tp.Count 
= 1;
        tp.Luid 
= 0;
        tp.Attr 
= SE_PRIVILEGE_ENABLED;
        result 
= LookupPrivilegeValue(null, SE_SHUTDOWN_NAME, ref tp.Luid);
        result 
= AdjustTokenPrivileges(htok, falseref tp, 0, IntPtr.Zero, IntPtr.Zero);
        result 
= InitiateSystemShutdown(""""60truefalse);
        
return result;
    }
    
#endregion
}
本文地址:http://www.cnblogs.com/anjou/archive/2006/11/30/577279.html

posted on 2006-11-30 09:14 大豆男生 阅读(539) 评论(3)  编辑 收藏 网摘 所属分类: .NET

评论

#1楼 2006-11-30 16:58 CkmXP[未注册用户]

有许多并不是很了解,希望大家可以一起努力   回复  引用    

#2楼[楼主] 2007-03-06 22:46 大豆男生      

@CkmXP
共勉!
  回复  引用  查看    




发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 577279




相关文章:

相关链接:

导航

公告


励志照亮人生,创业改变命运!

Blog 访问量,点击这里查看如何添加访问计数器。
<2006年11月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

统计

与我联系

搜索

 

常用链接

留言簿

我的标签

随笔分类(117)

随笔档案(121)

收藏夹(137)

我的连接

最新随笔

积分与排名

最新评论

阅读排行榜

评论排行榜