C# SOAP和证书授权
我需要使用基于SOAP和WSDL的web服务。SOAP(https)使用登录名、密码和证书进行身份验证。关于PHP的示例:C# SOAP和证书授权,c#,soap,ssl,wsdl,certificate,C#,Soap,Ssl,Wsdl,Certificate,我需要使用基于SOAP和WSDL的web服务。SOAP(https)使用登录名、密码和证书进行身份验证。关于PHP的示例: <? ... $client->authtype = 'certificate'; $client->decode_utf8 = 0; $client->soap_defencoding = 'UTF-8'; $client->certRequest['sslcertfile'] = 'path_to_cert.crt'; $client-&g
<?
...
$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");
...
?>
捕获异常:
无法建立信任关系
对于具有的SSL/TLS安全通道
权限“服务url”
试试这个:
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();
并捕获相同的异常。我需要做什么才能通过授权?谢谢你的回答。抱歉,英语不好:)如果您不需要用户名和密码,就不应该设置它-如果设置了密码,它可能不会使用客户端证书
对于证书本身,请确保它包含私钥,即嵌入私钥的PKCS12文件。我有cert.crt,但它不包含私钥。我还有文件private.key。也许我应该用它?如果是-如何?组合私钥和证书的一种方法是使用openssl pkcs12命令:
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();