Função CertSrvBackupGetDatabaseNamesW (certbcli.h)
A função CertSrvBackupGetDatabaseNames recupera a lista de nomes de arquivo de banco de dados dos Serviços de Certificados que precisam ser copiados em backup para o contexto de backup fornecido.
Sintaxe
HRESULT CERTBCLI_API CertSrvBackupGetDatabaseNamesW(
[in] HCSBC hbc,
[out] PWSTR *ppwszzAttachmentInformation,
[out] DWORD *pcbSize
);
Parâmetros
[in] hbc
Um identificador para um contexto de backup dos Serviços de Certificados.
[out] ppwszzAttachmentInformation
Um ponteiro para um ponteiro WCHAR que receberá a lista de nomes de arquivo de banco de dados terminados em nulo. Há um caractere nulo após cada nome de arquivo e um caractere nulo extra no final da lista. O nome do arquivo estará no formato UNC "## \\Server\SharePoint\... Path...\FileName.ext". Os nomes de diretório terão o mesmo formato, mas sem o "\FileName.ext" à direita. O texto "##" indica um tipo de arquivo de Backup dos Serviços de Certificados (CSBFT_*) e é armazenado como um único caractere Unicode não nulo prefixado em cada caminho UNC. A marca de tipo é definida em Certbcli.h e pode ser o valor a seguir para essa função.
Valor | Significado |
---|---|
|
Nome do arquivo de banco de dados dos Serviços de Certificados, incluindo caminho. |
Você deve liberar essa memória alocada quando terminar chamando CertSrvBackupFree. Antes de chamar essa função, definir *ppwszzAttachmentInformation como NULL é opcional.
[out] pcbSize
Um ponteiro para o valor DWORD que especifica o número de bytes em ppwszzAttachmentInformation.
Retornar valor
O valor retornado é um HRESULT. Um valor de S_OK indica êxito.
Comentários
O nome dessa função no Certadm.dll é CertSrvBackupGetDatabaseNamesW. Você deve usar essa forma do nome ao chamar GetProcAddress. Além disso, essa função é definida como o tipo FNCERTSRVBACKUPGETDATABASENAMESW no arquivo de cabeçalho Certbcli.h.
Exemplos
FNCERTSRVBACKUPGETDATABASENAMESW* pfnGetDBNames;
char * szGetDBNamesFunc = "CertSrvBackupGetDatabaseNamesW";
WCHAR * pwszzDBFiles;
DWORD nListBytes=0;
HRESULT hr=0;
// Get the address for the desired function.
// hInst was set by calling LoadLibrary for Certadm.dll.
pfnGetDBNames = (FNCERTSRVBACKUPGETDATABASENAMESW*)
GetProcAddress(hInst, szGetDBNamesFunc);
if ( NULL == pfnGetDBNames )
{
printf("Failed GetProcAddress - %s, error=%d\n",
szGetDBNamesFunc,
GetLastError() );
exit(1); // Or other appropriate error action.
}
// Determine the names of the database files.
// hCSBC was set by an earlier call to CertSrvBackupPrepare
hr = pfnGetDBNames(hCSBC, &pwszzDBFiles, &nListBytes);
if (FAILED(hr))
{
printf("Failed pfnGetDBNames call [%x]\n", hr);
exit(1); // Or other appropriate error action.
}
else
{
printf("%d bytes for DB file names\n", nListBytes);
WCHAR * pwszFile = pwszzDBFiles;
// Process the list.
while ( L'\0' != *pwszFile )
{
// Use the file name referenced by pwszFile.
// Here it is merely displayed.
printf("%02x: %ws\n", *pwszFile, &pwszFile[1]);
// Move to the next database file name.
// + 1 moves past the null terminator.
pwszFile+=(wcslen(pwszFile)) + 1;
}
// Free the allocated memory.
// pfnBackupFree is the address of the
// CertSrvBackupFree function.
pfnBackupFree(pwszzDBFiles);
}
Requisitos
Requisito | Valor |
---|---|
Cliente mínimo com suporte | Nenhum compatível |
Servidor mínimo com suporte | Windows Server 2003 [somente aplicativos da área de trabalho] |
Plataforma de Destino | Windows |
Cabeçalho | certbcli.h (inclua Certsrv.h) |
Biblioteca | Certadm.lib |
DLL | Certadm.dll |
Confira também
Usando as funções de backup e restauração dos Serviços de Certificados