Partager via


Comment : créer des certificats temporaires à utiliser au cours du développement

Lors du développement d'un service ou d'un client sécurisé à l'aide de Windows Communication Foundation (WCF), il est souvent nécessaire de fournir un certificat X.509 à utiliser comme informations d'identification. Le certificat fait en général partie d'une chaîne de certificats dont l'autorité racine est présente dans le magasin d'Autorités de certification racines de confiance de l'ordinateur. Une chaîne de certificats vous permet de définir la portée d'un jeu de certificats où en général l'autorité racine provient de votre organisation ou votre division. Pour émuler ce scénario au moment du développement, vous pouvez créer deux certificats pour satisfaire les conditions de sécurité. Le premier est un certificat auto-signé placé dans le magasin d'Autorités de certification racines de confiance. Le deuxième certificat est créé à partir du premier et placé dans le magasin personnel de l'emplacement de l'ordinateur local ou dans le magasin personnel de l'emplacement de l'utilisateur actif. Cette rubrique décrit les étapes permettant de créer ces deux certificats à l'aide de l'Certificate Creation Tool (MakeCert.exe) fourni par le Kit de développement logiciel (SDK) .NET Framework.

ms733813.Important(fr-fr,VS.100).gif Remarque :
Les certificats générés par l'outil de création de certification sont fournis uniquement à des fins de tests. Lorsque vous déployez un service ou un client, veillez à utiliser un certificat approprié fourni par une autorité de certification. Celui-ci peut provenir d'un serveur de certificat Windows Server 2003 dans votre organisation ou d'un tiers.

Par défaut, l'Certificate Creation Tool (MakeCert.exe) crée des certificats dont l'autorité racine est appelée « Agence Racine ». Comme celle-ci ne figure pas dans le magasin d'Autorités de certification racines de confiance, ces certificats ne sont pas sécurisés. La création d'un certificat auto-signé placé dans le magasin d'Autorités de certification racines de confiance vous permet de créer un environnement de développement qui reproduit plus fidèlement votre environnement de déploiement.

Pour plus d'informations sur le sujet suivant la création et l'utilisation de certificats, consultez Utilisation des certificats. Pour plus d'informations sur le sujet suivant l'utilisation d'un certificat comme information d'identification, consultez Sécurisation des services et des clients. Pour obtenir un didacticiel à propos de l'utilisation de la technologie Authenticode de Microsoft, consultez Vues d'ensemble et didacticiels relatifs à Authenticode (page éventuellement en anglais).

Pour créer un certificat d'autorité racine auto-signé et exporter la clé privée

  1. Utilisez l'outil MakeCert.exe avec les commutateurs suivants :

    1. -n subjectName. Spécifie le nom du sujet. La convention est de préfixer le nom du sujet avec "CN = ", abréviation de « Common Name ».

    2. -r. Spécifie que le certificat sera auto-signé.

    3. -sv privateKeyFile. Spécifie le fichier qui contient le conteneur de clé privée.

    Par exemple, la commande suivante crée un certificat auto-signé avec un nom de sujet de "CN=TempCA".

    makecert -n "CN=TempCA" -r -sv TempCA.pvk TempCA.cer
    

    Le système vous invite à fournir un mot de passe pour protéger la clé privée. Ce mot de passe est requis lors de la création d'un certificat signé par ce certificat racine.

Pour créer un nouveau certificat signé par un certificat d'autorité racine

  1. Utilisez l'outil MakeCert.exe avec les commutateurs suivants :

    1. -sk subjectKey. Emplacement du conteneur de clé du sujet comportant la clé privée. Un conteneur de clé sera créé s'il n'en existe aucun. Si aucune des options -sk ou -sv n'est utilisée, un conteneur de clé appelé JoeSoft est créé par défaut.

    2. -n subjectName. Spécifie le nom du sujet. La convention est de préfixer le nom du sujet avec "CN = ", abréviation de « Common Name ».

    3. -iv issuerKeyFile. Spécifie le fichier de clé privée de l'émetteur.

    4. -ic issuerCertFile. Spécifie l'emplacement du certificat de l'émetteur.

    Par exemple, la commande suivante crée un certificat signé par le certificat d'autorité racine TempCA avec "CN=SignedByCA" comme nom de sujet qui utilise la clé privée de l'émetteur.

    makecert -sk SignedByCA -iv TempCA.pvk -n "CN=SignedByCA" -ic TempCA.cer SignedByCA.cer -sr currentuser -ss My
    

Installation d'un certificat dans le magasin d'Autorités de certification racines de confiance

Une fois qu'un certificat auto-signé est créé, vous pouvez l'installer dans le magasin d'Autorités de certification racines de confiance. Tous les certificats signés à ce stade avec le certificat sont approuvés par l'ordinateur. Pour cette raison, supprimez le certificat du magasin dès que vous n'en avez plus besoin. Lorsque vous supprimez ce certificat d'autorité racine, tous les autres certificats ayant signé à l'aide de ce dernier ne sont plus autorisés. Les certificats d'autorité racines sont un simple mécanisme qui permet de définir la portée d'un groupe de certificats selon les besoins. Par exemple, dans les applications d'égal à égal, l'autorité racine n'est pas nécessaire le plus souvent dans la mesure où l'identité d'un individu est garantie par le certificat qu'il fournit.

Pour installer un certificat auto-signé dans les Autorités de certification racines de confiance

  1. Ouvrez le composant logiciel enfichable Certificat. Pour plus d'informations, consultez Comment : afficher des certificats à l'aide du composant logiciel enfichable MMC.

  2. Ouvrez le dossier pour stocker le certificat, soit Ordinateur local, soit Utilisateur actuel.

  3. Ouvrez le dossier Autorités de certification racines de confiance.

  4. Cliquez avec le bouton droit sur le dossier Certificats et cliquez sur Toutes les tâches, puis cliquez sur Importer.

  5. Suivez les instructions de l'Assistant à l'écran pour importer TempCa.cer dans le magasin.

Utilisation de certificats avec WCF

Une fois que vous avez configuré les certificats temporaires, vous pouvez les utiliser pour développer des solutions WCF qui spécifient des certificats comme un type d'informations d'identification du client. Par exemple, la configuration XML suivante spécifie la sécurité du message et un certificat comme type d'informations d'identification du client.

Pour spécifier un certificat comme type d'informations d'identification du client

  • Dans le fichier de configuration d'un service, utilisez le XML suivant pour affecter au mode de sécurité la valeur Message, et au type d'informations d'identification du client la valeur Certificat.

    <bindings>     
      <wsHttpBinding>
        <binding name="CertificateForClient">
          <security>
            <message clientCredentialType="Certificate" />
          </security>
        </binding>
      </wsHttpBinding>
    </bindings>
    

Dans le fichier de configuration d'un client, utilisez le XML suivant pour spécifier que le certificat est recherché dans le magasin de l'utilisateur, et qu'il peut être recherché dans le champ SubjectName en tapant la valeur « CohoWinery ».

<behaviors>
  <endpointBehaviors>
    <behavior name="CertForClient">
      <clientCredentials>
        <clientCertificate findValue="CohoWinery" x509FindType="FindBySubjectName" />
       </clientCredentials>
     </behavior>
   </endpointBehaviors>
</behaviors>

Pour plus d'informations sur l'utilisation des certificats dans WCF, consultez Utilisation des certificats.

Sécurité

Veillez à supprimer tous les certificats d'autorité racines temporaires des dossiers Autorités de certification racines de confiance et Personnel en cliquant avec le bouton droit sur le certificat, en cliquant sur ensuite Supprimer.

Voir aussi

Tâches

Comment : afficher des certificats à l'aide du composant logiciel enfichable MMC

Concepts

Utilisation des certificats

Autres ressources

Sécurisation des services et des clients