Partager via


SCardGetCardTypeProviderNameW, fonction (winscard.h)

La fonction SCardGetCardTypeProviderName retourne le nom du module (bibliothèque de liens dynamiques) qui contient le fournisseur pour un nom de carte donné et type de fournisseur.

Syntaxe

LONG SCardGetCardTypeProviderNameW(
  [in]      SCARDCONTEXT hContext,
  [in]      LPCWSTR      szCardName,
  [in]      DWORD        dwProviderId,
  [out]     WCHAR        *szProvider,
  [in, out] LPDWORD      pcchProvider
);

Paramètres

[in] hContext

Handle qui identifie le contexte Resource Manager. Le contexte resource manager peut être défini par un appel précédent à SCardEstablishContext. Cette valeur peut être NULL si l’appel à SCardGetCardTypeProviderName n’est pas dirigé vers un contexte spécifique.

[in] szCardName

Nom du type de carte auquel ce nom de fournisseur est associé.

[in] dwProviderId

Identificateur du fournisseur associé à ce type de carte.

Valeur Signification
SCARD_PROVIDER_PRIMARY
1
La fonction récupère le nom du fournisseur de services principalcarte à puce sous forme de chaîne GUID.
SCARD_PROVIDER_CSP
2
La fonction récupère le nom du fournisseur de services de chiffrement .
SCARD_PROVIDER_KSP
3
La fonction récupère le nom de la carte à puce fournisseur de stockage de clés (KSP).
SCARD_PROVIDER_CARD_MODULE
0x80000001
La fonction récupère le nom du module de carte.

[out] szProvider

Variable de chaîne pour recevoir le nom du fournisseur à la fin de cette fonction.

[in, out] pcchProvider

Pointeur vers valeur de DWORD. En entrée, pcchProvider fournit la longueur de la mémoire tampon szProvider en caractères. Si cette valeur est SCARD_AUTOALLOCATE, szProvider est converti en pointeur en pointeur d’octet et reçoit l’adresse d’un bloc de mémoire contenant la chaîne. Ce bloc de mémoire doit être libéré en appelant SCardFreeMemory.

Lors de la sortie, cette valeur représente le nombre réel de caractères, y compris le fin de null, dans la variable szProvider.

Valeur de retour

Cette fonction retourne des valeurs différentes selon qu’elle réussit ou échoue.

Retourner le code Description
Success
SCARD_S_SUCCESS.
échec
Code d’erreur. Pour plus d’informations, consultez valeurs de retour de carte à puce.

Remarques

Cette fonction n’est pas redirigée, mais l’appel de la fonction à l’intérieur d’une session Bureau à distance n’entraîne pas d’erreur. Cela signifie uniquement que le résultat provient de l’ordinateur distant au lieu de l’ordinateur local.

Une fois cette fonction terminée, la valeur de szProvider peut être utilisée comme troisième paramètre dans un appel à CryptAcquireContext.

Exemples

L’exemple suivant montre comment récupérer le nom du fournisseur pour le contexte de lecteur spécifié. L’exemple suppose que hContext est un handle valide obtenu à partir d’un appel précédent à la fonction SCardEstablishContext.

LPTSTR szProvider = NULL;
LPTSTR szCardName = _T("WindowsCard");
DWORD  chProvider = SCARD_AUTOALLOCATE;
LONG   lReturn = SCARD_S_SUCCESS;

// Retrieve the provider name.
// hContext was set by SCardEstablishContext.
lReturn = SCardGetCardTypeProviderName(hContext,
                                       szCardName,
                                       SCARD_PROVIDER_CSP,
                                       (LPTSTR)&szProvider,
                                       &chProvider);
if (SCARD_S_SUCCESS == lReturn)
{
    BOOL fSts = TRUE;
    HCRYPTPROV hProv = NULL;
  
  // Acquire a Cryptographic operation context.
    fSts = CryptAcquireContext(&hProv,
                               NULL,
                               szProvider,
                               PROV_RSA_FULL,
                               0);
    // Perform Cryptographic operations with smart card
    // ...

    // Free memory allocated by SCardGetCardTypeProviderName.
    lReturn = SCardFreeMemory(hContext, szProvider);
}

Note

L’en-tête winscard.h définit SCardGetCardTypeProviderName comme alias qui sélectionne automatiquement la version ANSI ou Unicode de cette fonction en fonction de la définition de la constante de préprocesseur UNICODE. Le mélange de l’utilisation de l’alias neutre en encodage avec du code qui n’est pas neutre en encodage peut entraîner des incompatibilités qui entraînent des erreurs de compilation ou d’exécution. Pour plus d’informations, consultez Conventions pour les prototypes de fonction.

Exigences

Exigence Valeur
client minimum pris en charge Windows XP [applications de bureau uniquement]
serveur minimum pris en charge Windows Server 2003 [applications de bureau uniquement]
plateforme cible Windows
d’en-tête winscard.h
bibliothèque Winscard.lib
DLL Winscard.dll

Voir aussi

SCardEstablishContext

SCardFreeMemory

SCardSetCardTypeProviderName