5

简洁版本

我想扩展SoapClient,所以它在访问 WSDL 时在内部执行此操作:

curl -L -E /location/of/cert.pem -c /tmp/location/of/cookie.jar https://web-service-provider/servicename?wsdl

长版

我有一个与此类似的 SOAP 请求:

$serviceUrl = 'https://service-url';
$wsdl = $serviceUrl . '?wsdl';

$proxyServiceUrl = 'http://localhost/myproxy.php?url=$serviceUrl';
$proxyWsdl = 'http://localhost/myproxy.php?url=$wsdl';

$options = array(
  'cache_wsdl'    => WSDL_CACHE_NONE,
  'encoding'      => 'utf-8',
  'soap_version'  => SOAP_1_1,
  'exceptions'    => true,
  'trace'         => true,
  'location'      => $proxyServiceUrl
);

$client = new SoapClient($proxyWsdl, $options);

$params = array( /* */ );
$client->someOperation($params);

如您所见,除了代理位之外,一切都非常标准。

代理的原因

我编写了代理来满足 Web 服务提供商的要求,即包括 WSDL 在内的所有端点都通过称为 siteminder 的身份验证系统进行处理。

代理的功能非常简单,如果用 linux 命令行 curl 编写,它会是这样的:

curl -L -E /location/of/cert.pem -c /tmp/location/of/cookie.jar https://web-service-provider/servicename?wsdl

准确地说:

* Follow all redirections
* specify location of .pem file (and password)
* specify location of cookie jar

这一切都很好:)

但是最近服务提供商决定改变它的 WSDL。

它现在导入模式文件 ( .xsd),这并没有那么糟糕,只是它与 WSDL 相关。

相对于 WSDL 文件意味着SoapClient解析器现在从代理的位置查找模式文件。错误,找不到!

有关该问题的更多详细信息:

php SoapClient 在传递具有相对路径模式的 wsdl 时失败

所以我的问题是:

我如何重写SoapClient(当然是通过扩展它),仍然通过站点管理员身​​份验证,但不必通过那个额外的代理?

我最初的想法是,我必须以某种方式重写 URI 访问器函数(如果存在),但在这方面没有太多文档,我不知道从哪里开始。

或者,我可能不得不以SoapServer某种方式破解。

如果我能得到任何帮助,我将不胜感激,包括指向SoapClient.

4

2 回答 2

2

如果只是提供 .pem 文件的问题,您是否查看local_cert过 SoapClient 构造函数的选项?然后,该客户端对象应保留为会话设置的任何 cookie。如果您还需要跨会话保留 cookie,您可以随时从响应中读取它们(使用__getLastResponseHeaders),然后使用__setCookie下次再次设置它们。

或者你可以让你的代理用绝对路径替换相对路径。毕竟,wsdl 本身就是一个 XML 文档。

或者你可以将你的代理变成一个实际的代理,并使用 proxy_host、proxy_port、proxy_login 和 proxy_password 选项。

于 2011-06-06T11:37:10.413 回答
2

这个挠头、拉头发的问题的答案可以在这里找到:

http://rabaix.net/en/articles/2008/03/13/using-soap-php-with-ntlm-authentication

感谢 php soap 邮件列表上的 Jeffery Fernandez 指出了这一点。

于 2011-06-07T08:18:13.560 回答