描述裝置
有兩種方式可取得裝置物件:
- 使用 IUPnPDescriptionDocument 介面。 IUPnPDescriptionDocument介面是唯一安全的指令碼介面。
- 使用 IUPnPDeviceFinder 介面來取得 IUPnPDevices 介面。
這兩種方法都會傳回 Devices 集合。 應用程式接著會使用 Device 方法來擷取裝置的相關屬性。
應用程式能夠擷取下列類型的資訊:
- 裝置階層資訊,包括根裝置、父裝置和子裝置。
- 裝置屬性,包括 UDN、統一資源識別項 (URI) ,以及使用者可讀取的名稱。
- 製造商資訊,包括名稱和相關的網頁。
- 模型資訊,包括名稱、數位、API、序號和裝置描述。
- 顯示資訊,包括用來控制裝置的 URL,以及從中下載圖示的 URL。
- 特定裝置所提供的服務。
應用程式也會使用 IUPnPDeviceDocumentAccess 介面取得裝置描述檔的 URL。 應用程式接著會載入描述檔,並使用 IUPnPDevice 介面未公開的裝置和服務屬性。 這個介面無法用於腳本,因為它不是預設介面。
Visual Basic範例
下列範例程式碼顯示 IUPnPDeviceDocumentAccess::GetDocumentURL的使用方式。
Sub GetDocumentURL()
Dim pDescDoc As IUPnPDeviceDocumentAccess
Dim strDescDocURL As String
'currentDevice is UPnPDevice object containing the current UPnP Device
'We are trying to get IUPnPDeviceDocumentAccess interface in the UPnP Device object
Set pDescDoc = currentDevice
If Not (pDescDoc is Nothing) Then
'Description Document URL is got from device
strDescDocURL = pDescDoc.GetDocumentURL
End If
C++ 範例
下列範例程式碼顯示 IUPnPDeviceDocumentAccess::GetDocumentURL的使用方式。
#include <windows.h>
#include <upnp.h>
#include <stdio.h>
#pragma comment(lib, "ole32.lib")
#pragma comment(lib, "oleaut32.lib")
int GetDeviceDocumentUrl ()
{
HRESULT hr = S_OK;
// List of interfaces needed
IUPnPDeviceFinder *pDevFinder=NULL;
IUPnPDevice *pDevice =NULL;
IUPnPDeviceDocumentAccess* pDeviceDocument=NULL;
BSTR bstrDeviceUDN =NULL;
BSTR bstrDeviceDocumentURL = NULL;
bstrDeviceUDN = SysAllocString(L"uuid:234324234324");
if(bstrDeviceUDN == NULL){
printf("ERROR: Could not allocate memory\n");
return -1;
}
//CoInitialize the program so that we can create COM objects
CoInitializeEx(NULL, COINIT_MULTITHREADED);
//now try to instantiate the DeviceFinder object
hr = CoCreateInstance( CLSID_UPnPDeviceFinder,
NULL,
CLSCTX_INPROC_SERVER,
IID_IUPnPDeviceFinder,
(LPVOID *) &pDevFinder);
if(!SUCCEEDED(hr)){
printf("\nERROR: CoCreateInstance on IUPnPDeviceFinder returned HRESULT %x",hr);
goto cleanup;
}
printf("\nGot a pointer to the IUPnPDeviceFinder Interface");
printf("\n Finding the device of given UDN\n");
hr =pDevFinder->FindByUDN(bstrDeviceUDN, &pDevice);
if(hr!=S_OK)
{
printf("\nERROR: FindByUDN for %S returned HRESULT %x", bstrDeviceUDN, hr);
goto cleanup;
}
printf("\n\tFindByUDN for device of UDN %S succeeded", bstrDeviceUDN);
//Now query pDevice for IUPnPDeviceDocumentAccess
hr = pDevice->QueryInterface(IID_IUPnPDeviceDocumentAccess, (VOID **)&pDeviceDocument);
if(SUCCEEDED(hr)){
// We have got a pointer to the IUPnPDeviceDocumentAccess interface.
// GetDocumentURL is available only in Windows XP.
hr = pDeviceDocument->GetDocumentURL(&bstrDeviceDocumentURL);
if(SUCCEEDED(hr))
printf("\nThe Device Document URL is %S \n", bstrDeviceDocumentURL);
}
cleanup:
//release references to all interfaces
if(pDevFinder)
pDevFinder->Release();
if(pDevice)
pDevice->Release();
if(pDeviceDocument)
pDeviceDocument->Release();
// Free the bstr strings
if(bstrDeviceDocumentURL)
SysFreeString(bstrDeviceDocumentURL);
if(bstrDeviceUDN)
SysFreeString(bstrDeviceUDN);
CoUninitialize();
return 0;
}