IADs::Metode GetEx (iads.h)
Metode IADs::GetEx mengambil, dari cache properti, nilai properti dari atribut tertentu. Nilai properti yang dikembalikan dapat bernilai tunggal atau multinilai. Tidak seperti metode IADs::Get , nilai properti dikembalikan sebagai array varian VARIAN, atau array varian byte untuk data biner. Properti bernilai tunggal kemudian direpresentasikan sebagai array dari satu elemen.
Sintaks
HRESULT GetEx(
[in] BSTR bstrName,
[out] VARIANT *pvProp
);
Parameter
[in] bstrName
Berisi BSTR yang menentukan nama properti.
[out] pvProp
Penunjuk ke VARIAN yang menerima nilai, atau nilai, properti .
Menampilkan nilai
Metode ini mendukung nilai pengembalian standar serta nilai pengembalian yang tercantum dalam daftar berikut.
Untuk informasi selengkapnya, lihat Kode Kesalahan ADSI.
Keterangan
Metode IADs::Get dan IADs::GetEx mengembalikan struktur varian yang berbeda untuk nilai properti bernilai tunggal. Jika properti adalah string, IADs::Get mengembalikan varian string (VT_BSTR), sedangkan IADs::GetEx mengembalikan array varian dari string jenis VARIAN dengan satu elemen. Dengan demikian, jika Anda tidak yakin bahwa atribut multinilai akan mengembalikan satu nilai atau beberapa nilai, gunakan IAD::GetEx. Karena tidak mengharuskan Anda untuk memvalidasi struktur data hasil, Anda mungkin ingin menggunakan IAD::GetEx untuk mengambil properti ketika Anda tidak yakin apakah ia memiliki satu atau beberapa nilai. Daftar berikut membandingkan dua metode.
IADs::Get version | IADs::GetEx version |
---|---|
|
|
Seperti iaDs::Get method, IADs::GetEx secara implisit memanggil IADs::GetInfo terhadap cache properti yang tidak diinisialisasi. Untuk informasi selengkapnya tentang panggilan implisit dan eksplisit ke IAD::GetInfo, lihat IADs::GetInfo.
Contoh
Contoh kode berikut menunjukkan cara menggunakan IAD::GetEx untuk mengambil properti objek.
Dim x As IADs
On Error GoTo ErrTest:
Set x = GetObject("LDAP://CN=Administrator,CN=Users,DC=Fabrikam,DC=com")
' Single value property.
Debug.Print "Home Phone Number is: "
phoneNumber = x.GetEx(""homePhone")
For Each homeNum in phoneNumber
Debug.Print homeNum
Next
' Multiple value property.
Debug.Print "Other Phone Numbers are: "
otherNumbers = x.GetEx("otherHomePhone")
For Each homeNum In otherNumbers
Debug.Print homeNum
Next
Exit Sub
ErrTest:
Debug.Print Hex(Err.Number)
Set x = Nothing
Contoh kode berikut menunjukkan cara mengambil nilai properti opsional objek menggunakan metode 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 the optional property values for this object.
Set cls = GetObject(x.Schema)
For Each op In cls.OptionalProperties
vals = obj.GetEx(op)
if err.Number = 0 then
Response.Write "Optional Property: & op & "="
for each v in vals
Response.Write v & " "
next
Response.Write "<br>"
end if
Next
%>
</body>
</html>
Contoh kode berikut mengambil nilai properti "homePhone" menggunakan IADs::GetEx.
IADs *pADs = NULL;
hr = ADsGetObject(L"LDAP://CN=Administrator,CN=Users,DC=Fabrikam,DC=Com", IID_IADs, (void**) &pADs );
if ( !SUCCEEDED(hr) ) { return hr;}
hr = pADs->GetEx(CComBSTR("homePhone"), &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 Home Phone using IADs::Get.\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 ( pADs )
{
pADs->Release();
}
Persyaratan
Klien minimum yang didukung | Windows Vista |
Server minimum yang didukung | Windows Server 2008 |
Target Platform | Windows |
Header | iads.h |
DLL | Activeds.dll |