XtfGetCredentialInfoList
現在本体に保存されている資格情報の一覧が含まれる XtfNetworkCredentials
オブジェクトを返します。
構文
HRESULT XtfGetCredentialInfoList(
LPCWSTR address,
XtfNetworkCredentials* credentialInfo
)
パラメーター
address
型: LPCWSTR
[in] 本体のアドレス。
credentialInfo
型: XtfNetworkCredentials*
[out] 現在本体に保存されている資格情報の一覧が含まれる XtfNetworkCredentials
オブジェクト。
戻り値
型: HRESULT
戻り値 S_OK
は、関数が成功し、credentialInfo オブジェクトから資格情報を取得できることを示します。 その他の値は、予期しないエラーが発生したことを示します。
解説
資格情報を追加するには、XtfAddCredential を使用します。 資格情報を削除するには、XtfRemoveCredential を使用します。 格納されている資格情報の最新の一覧を列挙するには、XtfGetCredentialInfoList、XtfGetCredentialInfoCount、XtfGetCredentialServerName、および XtfGetCredentialUserName を使用します。
XtfGetCredentialInfoList によって返される XtfNetworkCredentials
を解放するには、XtfCloseCredentialInfoList を使用します。
注意
XtfGetCredentialInfoList は本体からすべての情報を取得します。 XtfGetCredentialServerName と XtfGetCredentialUserName は、その取得した情報に対して反復処理のみを行います。
注意
必要な値を取得したら、XtfCloseCredentialInfoList を使用して、返された XtfNetworkCredentials オブジェクトと関連付けられているリソースを解放します。
HRESULT hr = S_OK;
PCWSTR consoleAddress = L"190.167.10.182";
XtfNetworkCredentials credentialInfo = nullptr;
UINT32 count = 0;
PWSTR pServerNameBuffer = nullptr;
PWSTR pUserNameBuffer = nullptr;
UINT32 bufferSize = 0;
hr = XtfAddCredential(consoleAddress, L"devpc001", L"devpc001\\test", L"test");
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfAddCredential failed 0x%x", hr);
return hr;
}
hr = XtfAddCredential(consoleAddress, L"devpc002", L"devpc002\\test1", L"test1");
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfAddCredential failed 0x%x", hr);
return hr;
}
hr = XtfGetCredentialInfoList(consoleAddress, &credentialInfo);
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfGetCredentialInfoList failed 0x%x", hr);
return hr;
}
hr = XtfGetCredentialInfoCount(credentialInfo, &count);
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfGetCredentialInfoCount failed 0x%x", hr);
return hr;
}
wprintf(L"\n\n*** List of Users:");
wprintf(L"\n\t*** Number of users: %d", count);
for (UINT32 i=0; i < count ; i++)
{
bufferSize=0;
hr = XtfGetCredentialServerName(credentialInfo, i, nullptr, &bufferSize);
if (hr != HRESULT_FROM_WIN32(ERROR_MORE_DATA))
{
wprintf(L"\n\n*** XtfGetCredentialServerName failed 0x%x", hr);
return hr;
}
pServerNameBuffer = new WCHAR[bufferSize];
hr = XtfGetCredentialServerName(credentialInfo, i, pServerNameBuffer, &bufferSize);
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfGetCredentialServerName failed 0x%x", hr);
return hr;
}
bufferSize=0;
hr = XtfGetCredentialUserName(credentialInfo, i, nullptr, &bufferSize);
if (hr != HRESULT_FROM_WIN32(ERROR_MORE_DATA))
{
wprintf(L"\n\n*** XtfGetCredentialUserName failed 0x%x", hr);
return hr;
}
pUserNameBuffer = new WCHAR[bufferSize];
hr = XtfGetCredentialUserName(credentialInfo, i, pUserNameBuffer, &bufferSize);
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfGetCredentialUserName failed 0x%x", hr);
return hr;
}
wprintf(L"\n\t Server: %ls, User: %ls", pServerNameBuffer, pUserNameBuffer);
delete[] pServerNameBuffer;
delete[] pUserNameBuffer;
}
XtfCloseCredentialInfoList(credentialInfo);
hr = XtfRemoveCredential(consoleAddress, L"devpc001");
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfRemoveCredential failed 0x%x", hr);
return hr;
}
hr = XtfRemoveCredential(consoleAddress, L"devpc002");
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfRemoveCredential failed 0x%x", hr);
return hr;
}
hr = XtfGetCredentialInfoList(consoleAddress, &credentialInfo);
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfGetCredentialInfoList failed 0x%x", hr);
return hr;
}
hr = XtfGetCredentialInfoCount(credentialInfo, &count);
if (FAILED(hr))
{
wprintf(L"\n\n*** XtfGetCredentialInfoCount failed 0x%x", hr);
return hr;
}
wprintf(L"\n\n*** Number of users: %d", count);
XtfCloseCredentialInfoList(credentialInfo);
wprintf(L"\n\n");
return hr;
要件
ヘッダー: xtfapi.h
ライブラリ: XtfApi.lib
サポートされているプラットフォーム: Windows (Xbox 本体ツール用)
関連項目
PC 展開から実行する (NDA トピック)認可が必須です
XTF トランスポート エラー (NDA トピック)認可が必須です
その他の Xtf API