J'ai besoin d'utiliser un service Web basé sur SOAP et WSDL. SOAP (https) utilise login, mot de passe et certificat pour authentifier. Exemple sur PHP:Autorisation SOAP et certificat
<?
...
$client->authtype = 'certificate';
$client->decode_utf8 = 0;
$client->soap_defencoding = 'UTF-8';
$client->certRequest['sslcertfile'] = 'path_to_cert.crt';
$client->certRequest['sslkeyfile'] = 'path_to_private.key';
$client->certRequest['cainfofile'] = 'path_to_cacert.pem';
$client->call("method");
...
?>
Comment puis-je faire cela sur C#? Ajouter le service de référence dans VS2008 et essayez ceci:
var ya = new YAPI.APIPortClient();
ya.Open();
ya.PingAPI();
Catch exception:
Impossible d'établir des relations de confiance pour le SSL/TLS canal sécurisé avec autorité 'URL du service.
Essayez ceci:
var ya = new YAPI.APIPortClient();
ya.ClientCredentials.UserName.UserName = "login";
ya.ClientCredentials.UserName.Password = "pass";
ya.ClientCredentials.ClientCertificate.Certificate = new X509Certificate2(@"path_to_cert.crt");
ya.Open();
ya.PingAPI();
et attrapez même exception. Qu'est-ce que je dois faire pour passer l'autorisation? Merci pour les réponses. Désolé pour un mauvais anglais :)
J'ai cert.crt, mais il ne contient pas de clé privée. Aussi j'ai fichier private.key. Peut-être que je devrais l'utiliser? Si oui - comment? –
Une façon de combiner une clé privée et un certificat est avec la commande openssl pkcs12: http://www.openssl.org/docs/apps/pkcs12.html –