基本認証の背後にあるWSDLからphpクラスを構築する必要があります。
たくさんの名前空間があるので、これを手作業で行うのは面倒です。
いくつかのツールを試しましたが、認証セッションが不安定であるようです。
$options = array(
'login' => $username,
'password' => $password,
);
$client = new SoapClient($wsdl, $options);
はい、動作します!私が構築していたソリューションで試してみましたが、HTTP Basic Authを使用している顧客WSに接続します。
HTTP AuthはSOAP Clientで動作しますが、パスワードで保護されたWSDLファイルにはアクセスできません
https://bugs.php.net/bug.php?id=27777 を参照してください
Lib nusoap を使用してこれを解決しました。役立つかどうかを確認する
$params = array(
"param" => "value"
);
$soap_client = new nusoap_client($wsdl_url, true);
$soap_client->setCredentials(USER_SERVICE, PASS_SERVICE, 'basic');
$soap_client->soap_defencoding = 'UTF-8'; //Fix encode erro, if you need
$soap_return = $soap_client->call("method_name", $params);
組み込みのSOAPクライアントを使用すると、次のようになります。
$options = array(
'login' => $username,
'password' => $password,
);
$client = new SoapClient($wsdl, $options);
このソリューションはどうですか:
このようなもの(簡易版):
class MySoap {
private $WSDL = 'https://secure-wsdl.url?wsdl';
private $USERNAME = 'dummy';
private $PASSWORD = 'dummy';
private $soapclient;
private function localWSDL()
{
$local_file_name = 'local.wsdl';
$local_file_path = 'path/to/file/'.$local_file_name;
// Cache local file for 1 day
if (filemtime($local_file_path) < time() - 86400) {
// Modify URL to format http://[username]:[password]@[wsdl_url]
$WSDL_URL = preg_replace('/^https:\/\//', "https://{$this->USERNAME}:{$this->PASSWORD}@", $this->WSDL);
$wsdl_content = file_get_contents($WSDL_URL);
if ($wsdl_content === FALSE) {
throw new Exception("Download error");
}
if (file_put_contents($local_file_path, $wsdl_content) === false) {
throw new Exception("Write error");
}
}
return $local_file_path;
}
private function getSoap()
{
if ( ! $this->soapclient )
{
$this->soapclient = new SoapClient($this->localWSDL(), array(
'login' => $this->USERNAME,
'password' => $this->PASSWORD,
));
}
return $this->soapclient;
}
public function callWs() {
$this->getSoap()->wsMethod();
}
}
わたしにはできる :)
これは、soapClientを使用してWebサービスを認証する簡単な例です
$apiauth =array('UserName'=>'abcusername','Password'=>'xyzpassword','UserCode'=>'1991');
$wsdl = 'http://sitename.com/service.asmx?WSDL';
$header = new SoapHeader('http://tempuri.org/', 'AuthHeader', $apiauth);
$soap = new SoapClient($wsdl);
$soap->__setSoapHeaders($header);
$data = $soap->methodname($header);
このコードは内部的に次のようにヘッダーを解析します
<soap:Header>
<AuthHeader xmlns="http://tempuri.org/">
<UserName>abcusername</UserName>
<Password>xyzpassword</Password>
<UserCode>1991</UserCode>
</AuthHeader>
</soap:Header>
私はこの問題を解決しようとしましたが、私が理解していることから、ssl + httpauth WebサービスへのSOAPクライアント接続はより苦痛です。私はグーグルで調べましたが、私の問題が解決されているので、以下の例を使用して問題を解決することもできます(urlとsoapClientセットアップの両方でHttpAuth情報を使用して).
$username="test";
$password="test";
$url = "https://".urlencode($username).":".urlencode($password)."@example.com/service.asmx?WSDL";
$context = stream_context_create([
'ssl' => [
// set some SSL/TLS specific options
'verify_peer' => false,
'verify_peer_name' => false,
'allow_self_signed' => true,
]]);
$client = new SoapClient($url, [
'location' => $url,
'uri' => $url,
'stream_context' => $context,
'login' => $username,
'password' => $password
]);
$params=array(
'operation'=>’arguments',
'and’=>'other bull',
'goes’=>'here'
);
$response = $client->__soapCall('OperationName', array($params));