青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

brent's hut

NT下判斷用戶是否有管理員權限

OK,  Thanks to Loaden found out that my original code to determine whether an user is in Administrators group is totally bullshit.

And after googling for a while, I found something and test it, simply works. I will just paste the code here. Thanks to the author and google and God.

http://www.mihai-nita.net/article.php?artID=20070413a
// IsAdminAPI.cpp : Tests if user is Administrator using plain Win32 API
// Copyright (c) April 2007, Mihai Nita
//

#include 
<wtypes.h>
#include 
<Lm.h>

// for ASSERT
#include <crtdbg.h>

#include 
"IsAdminAPI.h"

bool IsAdminAPI( WCHAR const *szUserName )
{
    _ASSERT(szUserName);

    
bool bAdmin = FALSE;
    LOCALGROUP_USERS_INFO_0
* localGroups;
    DWORD entriesread, totalentries;
    NET_API_STATUS nts 
= NetUserGetLocalGroups( NULL, szUserName, 00, (unsigned char**)&localGroups, MAX_PREFERRED_LENGTH, &entriesread, &totalentries);

    
if( nts != NERR_Success ) {
        NetApiBufferFree(localGroups);
        
return FALSE;
    }

    
// Retrieve the Administrators group well-known SID

    
// For some reason CreateWellKnownSid generates error C3861 on Developer Studio .NET:
    
// error C3861: 'CreateWellKnownSid': identifier not found, even with argument-dependent lookup
    BYTE    SidAuth[] = SECURITY_NT_AUTHORITY;
    PSID    pAdminSid;
    AllocateAndInitializeSid( (PSID_IDENTIFIER_AUTHORITY)SidAuth, 
        
2, SECURITY_BUILTIN_DOMAIN_RID, DOMAIN_ALIAS_RID_ADMINS, 
        NULL, NULL, NULL, NULL, NULL, NULL, 
&pAdminSid );

    
// Will use this to retrieve the SID of the group
    BYTE    buffSid[SECURITY_MAX_SID_SIZE];
    wchar_t    buffDomain[DNLEN
+1];
    DWORD    dwSidSize;
    DWORD    dwDomainSize;
    SID_NAME_USE m_sidnameuse;

    
for( DWORD i = 0; i < entriesread; ++i ) {
        dwSidSize 
= sizeof(buffSid);
        dwDomainSize 
= DNLEN;

        
// Although in general is a bad idea to call directly the W or A versions of API
        
// we do it here to avoid converting the localGroups[i].lgrui0_name back to ANSI
        
// This kind of security API is only present on NT/2000/XP family only, so
        
// the W version is present and safe to use
        if( LookupAccountNameW( NULL, localGroups[i].lgrui0_name, buffSid, &dwSidSize, (LPWSTR)buffDomain, &dwDomainSize, &m_sidnameuse) ) // no sid for the actual group
            if( EqualSid( buffSid, pAdminSid ) ) {
                bAdmin 
= TRUE;
                
break;
            }
    }
    FreeSid( pAdminSid );
    NetApiBufferFree(localGroups);

    
return bAdmin;
}


注意有時我們只需要判斷當前process是否以管理員權限運行。貌似可以通過調用GetTokenInformation 和AllocateAndInitializeSid 來判斷,

google "Searching for a SID in an Access Token in C++" site:msdn.microsoft.com可找到一段代碼, 請自行研究自行測試。

#define MAX_NAME 256

BOOL SearchTokenGroupsForSID (VOID) 
{
DWORD i, dwSize 
= 0, dwResult = 0;
HANDLE hToken;
PTOKEN_GROUPS pGroupInfo;
SID_NAME_USE SidType;
char lpName[MAX_NAME];
char lpDomain[MAX_NAME];
BYTE sidBuffer[
100];
PSID pSID 
= (PSID)&sidBuffer;
SID_IDENTIFIER_AUTHORITY SIDAuth 
= SECURITY_NT_AUTHORITY;
   
// Open a handle to the access token for the calling process.

if (!OpenProcessToken( GetCurrentProcess(), TOKEN_QUERY, &hToken )) {
    printf( 
"OpenProcessToken Error %u\n", GetLastError() );
    
return FALSE;
}

// Call GetTokenInformation to get the buffer size.

if(!GetTokenInformation(hToken, TokenGroups, NULL, dwSize, &dwSize)) {
    dwResult 
= GetLastError();
    
if( dwResult != ERROR_INSUFFICIENT_BUFFER ) {
        printf( 
"GetTokenInformation Error %u\n", dwResult );
        
return FALSE;
    }
}

// Allocate the buffer.

pGroupInfo 
= (PTOKEN_GROUPS) GlobalAlloc( GPTR, dwSize );

// Call GetTokenInformation again to get the group information.

if(! GetTokenInformation(hToken, TokenGroups, pGroupInfo, 
                        dwSize, 
&dwSize ) ) {
    printf( 
"GetTokenInformation Error %u\n", GetLastError() );
    
return FALSE;
   }

// Create a SID for the BUILTIN\Administrators group.

if(! AllocateAndInitializeSid( &SIDAuth, 2,
                 SECURITY_BUILTIN_DOMAIN_RID,
                 DOMAIN_ALIAS_RID_ADMINS,
                 
000000,
                 
&pSID) ) {
    printf( 
"AllocateAndInitializeSid Error %u\n", GetLastError() );
    
return FALSE;
   }

// Loop through the group SIDs looking for the administrator SID.

for(i=0; i<pGroupInfo->GroupCount; i++) {
    
if ( EqualSid(pSID, pGroupInfo->Groups[i].Sid) ) {

        
// Lookup the account name and print it.

        dwSize 
= MAX_NAME;
        
if!LookupAccountSid( NULL, pGroupInfo->Groups[i].Sid,
                              lpName, 
&dwSize, lpDomain, 
                              
&dwSize, &SidType ) ) {
            dwResult 
= GetLastError();
            
if( dwResult == ERROR_NONE_MAPPED )
               strcpy_s (lpName, dwSize, 
"NONE_MAPPED" );
            
else {
                printf(
"LookupAccountSid Error %u\n", GetLastError());
                
return FALSE;
            }
        }
        printf( 
"Current user is a member of the %s\\%s group\n"
                lpDomain, lpName );

        
// Find out whether the SID is enabled in the token.
        if (pGroupInfo->Groups[i].Attributes & SE_GROUP_ENABLED)
            printf(
"The group SID is enabled.\n");
         
else if (pGroupInfo->Groups[i].Attributes & 
                          SE_GROUP_USE_FOR_DENY_ONLY)
            printf(
"The group SID is a deny-only SID.\n");
         
else 
            printf(
"The group SID is not enabled.\n");
    }
}

if (pSID)
    FreeSid(pSID);
if ( pGroupInfo )
    GlobalFree( pGroupInfo );
return TRUE;
}

向曾被我誤導的同志表示真摯的道歉和沉痛的悼念。

NSIS下判斷當前用戶是否管理員:
http://nsis.sourceforge.net/Check_if_the_current_user_is_an_Administrator
!macro IsUserAdmin RESULT
 !define Index 
"Line${__LINE__}"
   StrCpy ${RESULT} 0
   System::Call 
'*(&i1 0,&i4 0,&i1 5)i.r0'
   System::Call 
'advapi32::AllocateAndInitializeSid(i r0,i 2,i 32,i 544,i 0,i 0,i 0,i 0,i 0, \
   i 0,*i .R0)i.r5'
   System::Free $0
   System::Call 
'advapi32::CheckTokenMembership(i n,i R0,*i .R1)i.r5'
   StrCmp $
5 0 ${Index}_Error
   StrCpy ${RESULT} $R1
   Goto ${Index}_End
 ${Index}_Error:
   StrCpy ${RESULT} 
-1
 ${Index}_End:
   System::Call 
'advapi32::FreeSid(i R0)i.r5'
 !undef Index
!macroend

posted on 2005-07-25 09:11 brent 閱讀(3298) 評論(2)  編輯 收藏 引用 所屬分類: C++Windows

評論

# re: NT下判斷用戶是否有管理員權限[未登錄] 2008-12-01 17:00 Loaden

有嚴重缺陷:如果用戶原來是管理員,后從管理員組中刪除,則上述代碼仍然認為是管理員。  回復  更多評論   

# re: NT下判斷用戶是否有管理員權限 2008-12-02 11:45 brent

Thanks, 已經更新了  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            91久久夜色精品国产网站| 亚洲国产精品美女| 国产三级精品三级| 国产精品五月天| 国产精品久久一级| 国产亚洲欧洲一区高清在线观看 | 夜夜躁日日躁狠狠久久88av| 国产精品视频久久| 国产日韩在线不卡| 亚洲国产一区在线观看| 亚洲精品国产日韩| 亚洲一区在线直播| 久久亚洲电影| 亚洲国产精品视频一区| 亚洲精品国产精品乱码不99按摩| 亚洲成人在线免费| 国产精品一区在线播放| 国产精品综合久久久| 国产日韩一区二区三区在线播放 | 欧美女同视频| 欧美三级在线视频| 国产专区欧美专区| 日韩亚洲在线| 久久精品日韩欧美| 欧美福利一区二区| 亚洲无线一线二线三线区别av| 亚洲午夜视频在线观看| 欧美一级二级三级蜜桃| 久久婷婷麻豆| 国产精品美女xx| 亚洲人午夜精品| 欧美中文字幕在线视频| 亚洲丁香婷深爱综合| 一本高清dvd不卡在线观看| 性感少妇一区| 欧美三级网址| 亚洲精品日韩久久| 久久在线视频| 亚洲欧美日韩精品久久久久| 久久精品综合一区| 国产精品视频免费观看www| 亚洲激情一区二区三区| 欧美一级午夜免费电影| 亚洲国产精品女人久久久| 欧美在线电影| 国产欧美日韩免费| 亚洲资源av| 999在线观看精品免费不卡网站| 久久成人av少妇免费| 欧美日韩在线三区| 亚洲免费高清| 91久久精品久久国产性色也91| 午夜视频在线观看一区二区三区 | 99www免费人成精品| 久久久久久久999精品视频| 国产精品久久久久久久久| 亚洲激情网站| 亚洲国产精品久久久久秋霞影院 | 国产精品色午夜在线观看| 亚洲精品日本| 亚洲欧洲精品成人久久奇米网| 久久久久高清| 在线观看久久av| 欧美14一18处毛片| 蜜桃av久久久亚洲精品| 国产综合自拍| 看片网站欧美日韩| 久久噜噜亚洲综合| 最新热久久免费视频| 欧美国产视频一区二区| 久热精品视频在线观看一区| 亚洲视频在线看| 女仆av观看一区| 久久精品二区三区| 在线精品视频一区二区三四| 亚洲欧美另类久久久精品2019| 亚洲精品久久7777| 欧美日韩另类丝袜其他| 99在线视频精品| 中日韩在线视频| 国产麻豆综合| 久热精品视频在线| 另类尿喷潮videofree| 亚洲激情视频在线观看| 亚洲国产色一区| 欧美午夜电影在线| 久久精品视频在线观看| 久久久99免费视频| 亚洲开发第一视频在线播放| 欧美国产日本| 国产精品区一区二区三| 久久美女性网| 欧美日本精品| 久久久久久穴| 欧美日韩精品一区二区天天拍小说| 亚洲天堂黄色| 久久精品99国产精品日本| 亚洲国产欧美久久| 亚洲在线免费视频| 亚洲精品视频在线播放| 亚洲一区二区精品在线| 狠狠色综合播放一区二区| 麻豆精品在线视频| 欧美色偷偷大香| 麻豆精品网站| 国产欧美va欧美va香蕉在| 欧美成人精品激情在线观看| 麻豆精品精华液| 欧美一区二区精品| 欧美精品久久久久久久| 久久视频免费观看| 欧美色区777第一页| 你懂的成人av| 国产亚洲午夜| 一区二区三区欧美在线观看| 国产精品久久久久三级| 免费在线欧美视频| 国产日韩欧美黄色| 在线中文字幕不卡| 日韩视频在线一区| 免费国产自线拍一欧美视频| 在线亚洲一区二区| 欧美aⅴ99久久黑人专区| 午夜精品久久久久久久白皮肤| 麻豆久久婷婷| 久久香蕉国产线看观看av| 欧美性视频网站| 亚洲精品久久在线| 日韩视频第一页| 欧美精品激情| 99re6这里只有精品| 亚洲国产一区二区a毛片| 小处雏高清一区二区三区| 亚洲图色在线| 欧美h视频在线| 狠狠干综合网| 久久久久久久精| 久久伊人一区二区| 永久91嫩草亚洲精品人人| 欧美在线看片| 久久躁日日躁aaaaxxxx| 国产亚洲精品久久久久动| 亚洲影院免费观看| 久久国产精品久久w女人spa| 欧美成年人网站| 亚洲经典在线看| 一区二区三区产品免费精品久久75| 免费看黄裸体一级大秀欧美| 久久久精品tv| 亚洲电影免费在线观看| 久久综合久色欧美综合狠狠| 欧美专区在线观看一区| 国产日本亚洲高清| 久久蜜臀精品av| 亚洲黄色一区二区三区| 亚洲久久一区二区| 国产精品毛片大码女人| 欧美一区二区三区日韩| 久久一区二区三区av| 在线观看亚洲一区| 欧美另类久久久品| 亚洲欧美日韩高清| 欧美国产高清| 亚洲女女女同性video| 国产日韩av在线播放| 久久大香伊蕉在人线观看热2| 久久人91精品久久久久久不卡| 在线观看国产精品淫| 欧美另类视频在线| 午夜久久久久| 亚洲黄色高清| 亚洲欧美综合v| 亚洲国产aⅴ天堂久久| 欧美人与性动交cc0o| 亚洲欧美成人网| 亚洲缚视频在线观看| 亚洲欧美国产精品桃花| 国内精品视频久久| 欧美日韩视频在线一区二区| 国产精品99久久99久久久二8 | 一区二区三区毛片| 国产手机视频一区二区| 免费亚洲视频| 欧美一级久久| 99国产精品国产精品久久 | 久久亚洲私人国产精品va| 亚洲第一视频| 国产精品毛片在线看| 欧美 日韩 国产 一区| 亚洲在线免费观看| 日韩午夜在线观看视频| 久久久国产视频91| 亚洲伊人久久综合| 亚洲精品无人区| 亚洲第一福利社区| 国产一区二区三区在线观看免费视频| 欧美乱在线观看| 另类激情亚洲| 久久久xxx| 久久国产精品久久久久久|