VC如何判断当前进程处在Administrator权限下

19 篇文章 0 订阅
18 篇文章 0 订阅

#include < windows.h >

#include < stdio.h >

BOOL IsAdmin(
void );

int  main( int argc, char * argv[])
{
  
if (IsAdmin())
       printf(
" IsAdmin - TRUE " );
  
else
       printf(
" IsAdmin - FALSE " );

   return 0;
}


BOOL IsAdmin(
void )
{
    HANDLE                   hAccessToken;
    BYTE                    
* InfoBuffer;
    PTOKEN_GROUPS            ptgGroups;
    DWORD                    dwInfoBufferSize;
    PSID                     psidAdministrators;
    SID_IDENTIFIER_AUTHORITY siaNtAuthority
= SECURITY_NT_AUTHORITY;
    UINT                     i;
    BOOL                     bRet
= FALSE;

   
if ( ! OpenProcessToken(GetCurrentProcess(),TOKEN_QUERY, & hAccessToken))
      
goto cleanup;
   
    InfoBuffer
= new BYTE[ 1024 ];
   
if ( ! InfoBuffer)
      
goto cleanup;

    bRet
= GetTokenInformation(hAccessToken,
                               TokenGroups,
                               InfoBuffer,
                              
1024 ,
                              
& dwInfoBufferSize);

    CloseHandle( hAccessToken );

   
if ( ! bRet)
      
goto cleanup;

   
if ( ! AllocateAndInitializeSid( & siaNtAuthority,
                                
2 ,
                                 SECURITY_BUILTIN_DOMAIN_RID,
                                 DOMAIN_ALIAS_RID_ADMINS,
                                
0 , 0 , 0 , 0 , 0 , 0 ,
                                
& psidAdministrators))
      
goto cleanup;

    bRet
= FALSE;

    ptgGroups
= (PTOKEN_GROUPS)InfoBuffer;

   
for (i = 0 ;i < ptgGroups -> GroupCount;i ++ )
    {
       
if (EqualSid(psidAdministrators,ptgGroups -> Groups[i].Sid))
        {
            bRet
= TRUE;
           
break ;
        }
    }

    FreeSid(psidAdministrators);

cleanup:

   
if (InfoBuffer)
        delete InfoBuffer;

   
return bRet;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值