Partager via


ISCardCmd::p ut_Apdu, méthode

[La méthode put_Apdu peut être utilisée dans les systèmes d’exploitation spécifiés dans la section Configuration requise. Il n’est pas disponible pour une utilisation dans Windows Server 2003 avec Service Pack 1 (SP1) et versions ultérieures, Windows Vista, Windows Server 2008 et les versions ultérieures du système d’exploitation. Les modules de carte à puce offrent des fonctionnalités similaires.]

La méthode put_Apdu copie l’unité de données de protocole d’application (APDU) de l’objet IByteBuffer (IStream) dans l’APDU encapsulé dans cet objet d’interface.

Syntaxe

HRESULT put_Apdu(
  [in] LPBYTEBUFFER pApdu
);

Paramètres

pApdu [in]

Pointeur vers l’API ISO 7816-4 à copier.

Valeur retournée

La méthode retourne l’une des valeurs possibles suivantes.

Code de retour Description
S_OK
Opération exécutée avec succès.
E_INVALIDARG
Le paramètre pApdu n’est pas valide.
E_POINTER
Un pointeur incorrect a été passé dans pApdu.
E_OUTOFMEMORY
Mémoire insuffisante.

 

Notes

Pour récupérer l’API brute à partir de la mémoire tampon d’octets mappée via un IStream qui contient le message APDU, appelez get_Apdu.

Pour obtenir la liste de toutes les méthodes fournies par cette interface, consultez ISCardCmd.

En plus des codes d’erreur COM répertoriés ci-dessus, cette interface peut retourner un code d’erreur de carte intelligent si une fonction de carte intelligente a été appelée pour terminer la demande. Pour plus d’informations, consultez Valeurs de retour de carte à puce.

Exemples

L’exemple suivant montre comment copier un APDU à partir d’un objet IByteBuffer (IStream) dans l’APDU encapsulé dans un objet d’interface. L’exemple suppose que pIByteApdu est un pointeur valide vers un instance de IByteBuffer et que pISCardCmd est un pointeur valide vers un instance de l’interface ISCardCmd.

HRESULT    hr;


// Set the APDU.
hr = pISCardCmd->put_Apdu(pIByteApdu);
if (FAILED(hr)) 
{
    printf("Failed put_Apdu.\n");
    // Take other error handling action as needed.
}

Spécifications

Condition requise Valeur
Client minimal pris en charge
Windows XP [applications de bureau uniquement]
Serveur minimal pris en charge
Windows Server 2003 [applications de bureau uniquement]
Fin de la prise en charge des clients
Windows XP
Fin de la prise en charge des serveurs
Windows Server 2003
En-tête
Scarddat.h
Bibliothèque de types
Scarddat.tlb
DLL
Scardssp.dll
IID
IID_ISCardCmd est défini comme D5778AE3-43DE-11D0-9171-00AA00C18068

Voir aussi

get_Apdu

ISCardCmd