The SoapHeader class
(PHP 5, PHP 7, PHP 8)
简介
Represents a SOAP header.
类摘要
class SoapHeader
{
/* 属性 */
/* 方法 */
__construct(
string
string
mixed
bool
string
)
}string
$namespace
,string
$name
,mixed
$data
= ?,bool
$mustunderstand
= ?,string
$actor
= ?)
属性
- actor
-
- data
-
- mustUnderstand
-
- name
-
- namespace
-
目录
- SoapHeader::__construct — SoapHeader constructor
data:image/s3,"s3://crabby-images/00698/00698142cd7f9d7f9bd4fdcf9bee9cb315da9f05" alt="add a note"
User Contributed Notes 4 notes
john at jtresponse dot co dot uk ¶
10 years ago
None of the examples really do it for me.
Note: you should NOT need to hard-code any XML.
Here is an example of creating a nested header and including a parameter.
$client = new SoapClient(WSDL,array());
$auth = array(
'UserName'=>'USERNAME',
'Password'=>'PASSWORD',
'SystemId'=> array('_'=>'DATA','Param'=>'PARAM'),
);
$header = new SoapHeader('NAMESPACE','Auth',$auth,false);
$client->__setSoapHeaders($header);
Gives the following header XML:
<SOAP-ENV:Header>
<ns1:Auth>
<ns1:SystemId Param="PARAM">DATA</ns1:SystemId>
<ns1:UserName>USERNAME</ns1:UserName>
<ns1:Password>PASSWORD</ns1:Password>
</ns1:Auth>
</SOAP-ENV:Header>
ericvaneldik at gmail dot com ¶
3 years ago
If you want to create an soap header wihtout namespace and without an item key value setup, you can use SoapVar
To get this:
<SOAP-ENV:Header>
<IdentityHeader>
<SessionID>123456789</SessionID>
</IdentityHeader>
</SOAP-ENV:Header>
you can use this php code:
<?php
$headerVar = new SoapVar('<IdentityHeader><SessionID>123456789</SessionID></IdentityHeader>',
XSD_ANYXML);
$header = new SoapHeader('http://tempuri.org/','RequestParams',
$headerVar);
?>
abdul dot rashid at paytabs dot co ¶
6 years ago
Just to add some note regarding his john at jtresponse dot co dot uk
In PHP you can try following code to avoid the <item><key/>
$Auth = new stdClass();
$Auth->SystemId = "DATA";
$Auth->UserName = "USERNAME";
$Auth->Password = "PASSWORD";
$header = new SoapHeader('NAMESPACE','Auth',$Auth,false);
$soapClient->__setSoapHeaders($header);
<SOAP-ENV:Header>
<ns1:Auth>
<ns1:SystemId>DATA</ns1:SystemId>
<ns1:UserName>USERNAME</ns1:UserName>
<ns1:Password>PASSWORD</ns1:Password>
</ns1:Auth>
</SOAP-ENV:Header>
voroks at logics dot net dot au ¶
6 years ago
Example by john at jtresponse dot co dot uk does miss one important point: to be able to add attributes they must be mentioned in WSDL. If they not exist in WSDL they WILL NOT appear as attributes but rather <item><key/><value/></item> elements.