Composition des SPN d’un service avec un SCP

L’exemple de code suivant compose un SPN pour un service qui utilise un point de connexion de service (SCP). Le SPN retourné a le format suivant.

<service class>/<host>/<service name>

«< service class> » et «< service name> » correspondent aux paramètres pszDNofSCP et pszServiceClass . «< host> » est défini par défaut sur le nom DNS de l’ordinateur local.

DWORD
SpnCompose(
    TCHAR ***pspn,          // Output: an array of SPNs
    unsigned long *pulSpn,  // Output: the number of SPNs returned
    TCHAR *pszDNofSCP,      // Input: DN of the service's SCP
    TCHAR* pszServiceClass) // Input: the name of the service class
{
DWORD   dwStatus;    
 
dwStatus = DsGetSpn(
    DS_SPN_SERVICE, // Type of SPN to create (enumerated type)
    pszServiceClass, // Service class - a name in this case
    pszDNofSCP, // Service name - DN of the service SCP
    0, // Default: omit port component of SPN
    0, // Number of entries in hostnames and ports arrays
    NULL, // Array of hostnames. Default is local computer
    NULL, // Array of ports. Default omits port component
    pulSpn, // Receives number of SPNs returned in array
    pspn // Receives array of SPN(s)
    );
 
return dwStatus;
}