windows 7 पहल मुझे कैसे पता लगा सकता है कि मेरी प्रक्रिया यूएसी-उन्नत या नहीं चल रही है?




मुझे कैसे पता ना चला सोंग (4)

मेरा विस्टा एप्लिकेशन को यह जानने की आवश्यकता है कि उपयोगकर्ता ने इसे "व्यवस्थापक के रूप में" (उन्नत) या मानक उपयोगकर्ता (गैर-उन्नत) के रूप में लॉन्च किया है। मैं उस समय को कैसे पता लगा सकता हूं?


मुझे नहीं लगता कि ऊँचाई का प्रकार वह जवाब है जो आप चाहते हैं। आप बस जानना चाहते हैं कि यह ऊंचा है या नहीं। जब आप GetTokenInformation पर कॉल करते हैं, तो टोकनएवलेशन टाइप के बजाय टोकनउच्चरण का उपयोग करें यदि संरचना एक सकारात्मक मूल्य देता है, तो उपयोगकर्ता व्यवस्थापक है। यदि शून्य है, तो उपयोगकर्ता सामान्य ऊंचाई है।

यहां एक डेल्फी समाधान है:

function TMyAppInfo.RunningAsAdmin: boolean;
var
  hToken, hProcess: THandle;
  pTokenInformation: pointer;
  ReturnLength: DWord;
  TokenInformation: TTokenElevation;
begin
  hProcess := GetCurrentProcess;
  try
    if OpenProcessToken(hProcess, TOKEN_QUERY, hToken) then try
      TokenInformation.TokenIsElevated := 0;
      pTokenInformation := @TokenInformation;
      GetTokenInformation(hToken, TokenElevation, pTokenInformation, sizeof(TokenInformation), ReturnLength);
      result := (TokenInformation.TokenIsElevated > 0);
    finally
      CloseHandle(hToken);
    end;
  except
   result := false;
  end;
end;

उन लोगों के लिए, जो कि सी # में काम कर रहे हैं, विंडोज एसडीके में "क्रॉस टेक्नोलॉजी सैंपल" के एक भाग के रूप में एक "यूएसीडीएमओ" एप्लीकेशन है। वे यह पाते हैं कि वर्तमान उपयोगकर्ता इस विधि का उपयोग कर एक व्यवस्थापक है:

private bool IsAdministrator
{
    get
    {
        WindowsIdentity wi = WindowsIdentity.GetCurrent();
        WindowsPrincipal wp = new WindowsPrincipal(wi);

        return wp.IsInRole(WindowsBuiltInRole.Administrator);
    }
}

(ध्यान दें: मैंने मूल कोड को एक "संपत्ति" होने के बजाय "if" स्टेटमेंट के बजाय पुनर्रचना की है)


निम्न C ++ फ़ंक्शन ऐसा कर सकता है:

HRESULT GetElevationType( __out TOKEN_ELEVATION_TYPE * ptet );

/*
Parameters:

ptet
    [out] Pointer to a variable that receives the elevation type of the current process.

    The possible values are:

    TokenElevationTypeDefault - This value indicates that either UAC is disabled, 
        or the process is started by a standard user (not a member of the Administrators group).

    The following two values can be returned only if both the UAC is enabled
    and the user is a member of the Administrator's group:

    TokenElevationTypeFull - the process is running elevated. 

    TokenElevationTypeLimited - the process is not running elevated.

Return Values:

    If the function succeeds, the return value is S_OK. 
    If the function fails, the return value is E_FAIL. To get extended error information, call GetLastError().

Implementation:
*/

HRESULT GetElevationType( __out TOKEN_ELEVATION_TYPE * ptet )
{
    if ( !IsVista() )
        return E_FAIL;

    HRESULT hResult = E_FAIL; // assume an error occurred
    HANDLE hToken   = NULL;

    if ( !::OpenProcessToken( 
                ::GetCurrentProcess(), 
                TOKEN_QUERY, 
                &hToken ) )
    {
        return hResult;
    }

    DWORD dwReturnLength = 0;

    if ( ::GetTokenInformation(
                hToken,
                TokenElevationType,
                ptet,
                sizeof( *ptet ),
                &dwReturnLength ) )
    {
            ASSERT( dwReturnLength == sizeof( *ptet ) );
            hResult = S_OK;
    }

    ::CloseHandle( hToken );

    return hResult;
}

यहां एक वीबी 6 का कार्यान्वयन है, यदि एक (वर्तमान) प्रक्रिया को ऊंचा किया गया है

Option Explicit

'--- for OpenProcessToken
Private Const TOKEN_QUERY                   As Long = &H8
Private Const TokenElevation                As Long = 20

Private Declare Function GetCurrentProcess Lib "kernel32" () As Long
Private Declare Function OpenProcessToken Lib "advapi32.dll" (ByVal ProcessHandle As Long, ByVal DesiredAccess As Long, TokenHandle As Long) As Long
Private Declare Function GetTokenInformation Lib "advapi32.dll" (ByVal TokenHandle As Long, ByVal TokenInformationClass As Long, TokenInformation As Any, ByVal TokenInformationLength As Long, ReturnLength As Long) As Long
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long


Public Function IsElevated(Optional ByVal hProcess As Long) As Boolean
    Dim hToken          As Long
    Dim dwIsElevated    As Long
    Dim dwLength        As Long

    If hProcess = 0 Then
        hProcess = GetCurrentProcess()
    End If
    If OpenProcessToken(hProcess, TOKEN_QUERY, hToken) Then
        If GetTokenInformation(hToken, TokenElevation, dwIsElevated, 4, dwLength) Then
            IsElevated = (dwIsElevated <> 0)
        End If
        Call CloseHandle(hToken)
    End If
End Function






elevation