Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/305.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# SOAP和证书授权_C#_Soap_Ssl_Wsdl_Certificate - Fatal编程技术网

C# SOAP和证书授权

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

我需要使用基于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->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();