IADs::Get 方法 (iads.h)

IADs::Get方法會從屬性快取中擷取指定名稱的屬性。 屬性可以是單一值或多重值。 屬性值會表示為單一值屬性的變體,或 VARIANT 陣列 (VARIANT 或允許 多個值之屬性) 的位元組陣列。

語法

HRESULT Get(
  [in]  BSTR    bstrName,
  [out] VARIANT *pvProp
);

參數

[in] bstrName

包含指定屬性名稱的 BSTR

[out] pvProp

接收 屬性值的 VARIANT 指標。 如果是多重值屬性,除非屬性是二進位類型, 否則 pvPropVARIANT的 Variant 陣列。 在此後例中, pvProp 是位元組的變異陣列, (VT_U1 或VT_ARRAY) 。 對於參考物件的 屬性, pvProp 是所參考物件的VT_DISPATCH指標。

傳回值

這個方法支援標準傳回值,以及下列專案。

如需詳細資訊,請參閱 ADSI 錯誤碼

備註

IADs::Get方法需要呼叫端以不同的方式處理單一和多重值屬性值。 因此,如果您知道感興趣的屬性是單一或多重值,請使用 IADs::Get 方法來擷取屬性值。 下列程式碼範例示範呼叫者如何在呼叫此方法時處理單一和多重值屬性。

當屬性未初始化時,呼叫這個方法會叫用 對 IADs::GetInfo 方法的隱含呼叫。 這會從基礎目錄載入,儲存尚未在快取中設定的支援屬性值。 任何後續對 IADs::Get 的呼叫只會處理快取中的屬性值。 如需隱含和明確呼叫 IADs::GetInfo行為的詳細資訊,請參閱 IADs::GetInfo

您也可以使用 IADs::GetEx 從屬性快取擷取屬性值。 不過,不論這些值是單一值還是多重值,都會傳回為 VARIANT的 variant 陣列。 也就是說,ADSI 會嘗試以一致的資料格式封裝傳回的屬性值。 這可讓您在不確定傳回的資料有單一或多個值時,以呼叫者身分驗證資料類型的工作。

範例

下列程式碼範例會使用 IADs::Get擷取物件的安全性描述項。

Dim x As IADs
Dim Desc As IADsSecurityDescriptor
On Error GoTo ErrTest:
 
Set x = GetObject("LDAP://CN=Administrator,CN=Users,DC=Fabrikam,DC=com")
 
' Single-valued properties.
Debug.Print "Home Phone Number is: " & x.Get("homePhone")
 
' Some property values represents other ADSI objects. 
' Consult your provider documentation.
Set Desc = x.Get("ntSecurityDescriptor")
 
' Multi-valued property, assuming that multiple values were
' assigned to the "otherHomePhone" properties. Caller must 
' enumerate all the available values.
Debug.Print "Other Phone Numbers are: "
otherNumbers = x.Get("otherHomePhone")
For Each homeNum In otherNumbers
  Debug.Print homeNum
Next
 
Exit Sub
 
ErrTest:
  Debug.Print Hex(Err.Number)
  Set x = Nothing
  Set Desc = Nothing

下列程式碼範例示範如何使用 IADs::GetIADs::P ut來處理二進位資料的屬性值。

Dim oTarget As IADs
Dim Octet(5) As Byte
Dim MultiOctet(2) As Variant
Dim i As Integer, j As Integer

On Error GoTo Cleanup
 
' Set up MultiOctetString.
For i = 0 To 2
    For j = 0 To 5
        Octet(j) = CByte(i * j)
    Next j
    MultiOctet(i) = Octet
Next i
 
' Bind to the object and set MultiOctetString.
Set oTarget=GetObject("LDAP://CN=SomeUser,CN=Users,DC=Fabrikam, DC=COM")
oTarget.Put "multiOctetString", MultiOctet
oTarget.SetInfo
 
Dim GetOctet As Variant
Dim Temp As Variant
 
' Read back and print MultiOctetString.
GetOctet = oTarget.Get("multiOctetString")
For i = LBound(GetOctet) To UBound(GetOctet)
    Temp = GetOctet(i)
    For j = LBound(Temp) To UBound(Temp)
        Debug.Print Temp(j)
    Next j
    Debug.Print "----"
Next i

Exit Sub

Cleanup:
   MsgBox("An error has occurred. " & Err.Number)
   Set oTarget = Nothing

下列程式碼範例示範如何使用 IADs::Get擷取物件的選擇性屬性值。

<HTML>
<head><title></title></head>

<body>
<%
Dim x 
 
On error resume next
Set x = GetObject("WinNT://Fabrikam/Administrator")
Response.Write "Object Name: " & x.Name & "<br>"
Response.Write "Object Class: " & x.Class & "<br>"
 
' Get optional property values of this object.
Set cls = GetObject(x.Schema)

For Each op In cls.OptionalProperties
   v = obj.Get(op)
   if err.Number = 0 then
       Response.Write "Optional Property: " & op & "=" & v & "<br>"
   end if
Next
%>

</body>
</html>

下列程式碼範例會使用 IADs::Get讀取具有單一和多個值的屬性。

HRESULT hr;
IADs *pUsr=NULL;
 
CoInitialize(NULL);
 
///////////////////////////////
// Bind to a directory object.
///////////////////////////////
hr = ADsGetObject(L"WinNT://Fabrikam/Administrator,user", IID_IADs, (void**) &pUsr );
if ( !SUCCEEDED(hr) ) { return hr; }
 
//////////////////////////////////
// Get a single-valued attribute.
//////////////////////////////////
VARIANT var;
VariantInit(&var);
 
hr = pUsr->Get(CComBSTR("FullName"), &var );
if ( SUCCEEDED(hr) )
{
    printf("FullName: %S\n", V_BSTR(&var) );
    VariantClear(&var);
}
 
if ( pUsr )
{
    pUsr->Release();
}
 
///////////////////////////////////////////////////////
// Get a multi-valued attribute from a service object.
///////////////////////////////////////////////////////
IADs *pSvc = NULL;
 
hr = ADsGetObject(L"WinNT://Fabrikam/Account/Browser,service", IID_IADs, (void**) &pSvc );
if ( !SUCCEEDED(hr) )
{
    return hr;
}
 
hr = pSvc->Get(CComBSTR("Dependencies"), &var );
if ( SUCCEEDED(hr) )
{
    LONG lstart, lend;
    SAFEARRAY *sa = V_ARRAY( &var );
    VARIANT varItem;
 
    // Get the lower and upper bound.
    hr = SafeArrayGetLBound( sa, 1, &lstart );
    hr = SafeArrayGetUBound( sa, 1, &lend );
 
    // Iterate and print the content.
    VariantInit(&varItem);
    printf("Getting service dependencies using IADs :\n");
    for ( long idx=lstart; idx <= lend; idx++ )
    {
        hr = SafeArrayGetElement( sa, &idx, &varItem );
        printf("%S ", V_BSTR(&varItem));
        VariantClear(&varItem);
    }
    printf("\n");
 
    VariantClear(&var);
}
 
// Cleanup.
if ( pSvc )
{
    pSvc->Release();
}

需求

   
最低支援的用戶端 Windows Vista
最低支援的伺服器 Windows Server 2008
目標平台 Windows
標頭 iads.h
Dll Activeds.dll

另請參閱

IADs

IADs::GetEx

IADs::GetInfo

IADs::P ut

IADs::P utEx

屬性快取