[英]Call SOAP method via CURL in PHP,call require client authentication
概述:
该代码是关于使用 SOAP 和 Curl 调用 escreen Web 服务,并且需要客户端身份验证。 目前我没有得到任何结果,只有 HTTP 403 和 500 错误。 该调用要求客户端身份验证证书位于调用站点上。
代码:
$content = "<TicketRequest>
<Version>1.0</Version>
<Mode>Test</Mode>
<CommitAction></CommitAction>
<PartnerInfo>
<UserName>xxxxxxxxxx</UserName>
<Password>xxxxxxxxxxx</Password>
</ PartnerInfo>
<RequestorOrderID></RequestorOrderID>
<CustomerIdentification>
<IPAddress></IPAddress>
<ClientAccount>xxxxxxxxxx</ClientAccount>
<ClientSubAccount>xxxxxxxxxx</ClientSubAccount>
<InternalAccount></InternalAccount>
<ElectronicClientID></ElectronicClientID>
</CustomerIdentification>
<TicketAction>
<Type></Type>
<Params>
<Param>
<ID>4646</ID>
<Value></Value>
</Param>
</Params>
</TicketAction>
</TicketRequest>";
$wsdl = "https://services.escreen.com/SingleSignOnStage/SingleSignOn.asmx";
$headers = array( "Content-type: text/xml;charset=\"utf-8\"",
"Accept: text/xml",
"Cache-Control: no-cache",
"Pragma: no-cache",
// "SOAPAction: \"\"",
"Content-length: ".strlen($content),
);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $wsdl);
curl_setopt($ch, CURLOPT_HEADER, 1);
curl_setopt($ch, CURLOPT_VERBOSE, '1');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $content);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, '1');
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, '1');
//curl_setopt($ch, CURLOPT_HTTPHEADER, array("Content-Type: text/xml"));
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
//curl_setopt($ch, CURLOPT_HTTPHEADER, array('SOAPAction: ""'));
curl_setopt($ch, CURLOPT_CAPATH, '/home/pps/');
curl_setopt($ch, CURLOPT_CAINFO, '/home/pps/authority.pem');
curl_setopt($ch, CURLOPT_SSLCERT, 'PROTPLUSSOL_SSO.pem');
curl_setopt($ch, CURLOPT_SSLCERTPASSWD, 'xxxxxxxxxxxx');
$output = curl_exec($ch);
// Check if any error occured
if(curl_errno($ch))
{
echo 'Error no : '.curl_errno($ch).' Curl error: ' . curl_error($ch);
}
print_r($output);
问题:
我需要调用 RequestTicket 方法并将 XML 字符串传递给它。 我不知道在这里怎么做(传递方法名称来调用)。
对于客户端身份验证,他们给了我们三个证书,一个根证书,一个中间证书和一个客户端身份验证证书 PROTPLUSSOL_SSOpem(它是一个 .pfx 文件)。 由于我们在 linux 上,我们将它们转换为 pem 。 在 curl 调用中,我找不到如何同时包含根证书和中间证书的方法,因此我通过创建一个新的 pem 文件并复制中间证书和根证书并将其命名为 authority.pem 来组合它们。 我不确定它是否有效,并希望得到您的意见。
对于当前代码,我收到错误错误号:77 卷曲错误:错误设置证书验证位置:CAfile:/home/pps/authority.pem CApath:/home/pps/
如果我禁用 curl 错误消息,我会看到页面标题为 403 - Forbidden 的空白页面。 访问被拒绝。
如果我注释掉 CURLOPT_CAPATH 和 CURLOPT_CAINFO 行,它会给出 http 500 错误页面,消息作为内容,下面是顶部。
HTTP/1.1 500 内部服务器错误。 缓存控制:私有内容类型:文本/html 服务器:Microsoft-IIS/7.5 X-AspNet-版本:1.1.4322 X-Powered-By:ASP.NET 日期:2010 年 9 月 2 日星期四 14:46:38 GMT内容长度:1208
如果我注释掉如上以及 CURLOPT_SSLCERT 和 CURLOPT_SSLCERTPASSWD 它会给出 403 错误,消息作为内容。
所以我会请求你通过指出当前代码有什么问题来帮助我。
谢谢。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.