mirror of
https://github.com/php/php-src.git
synced 2025-08-16 05:58:45 +02:00
Fixed bug #38004 Parameters in SoapServer are decoded twice
This commit is contained in:
parent
f66cd50510
commit
c389a653f7
4 changed files with 95 additions and 2 deletions
1
NEWS
1
NEWS
|
@ -82,6 +82,7 @@ PHP NEWS
|
|||
|
||||
- Fixed memory leaks in openssl streams context options. (Pierre)
|
||||
- Fixed handling of extremely long paths inside tempnam() function. (Ilia)
|
||||
- Fixed bug #38004 Parameters in SoapServer are decoded twice. (Dmitry)
|
||||
- Fixed bug #38003 (in classes inherited from MySQLi it's possible to call
|
||||
private constructors from invalid context). (Tony)
|
||||
- Fixed bug #37987 (invalid return of file_exists() in safe mode). (Ilia)
|
||||
|
|
|
@ -1353,11 +1353,12 @@ static zval *to_zval_object_ex(encodeTypePtr type, xmlNodePtr data, zend_class_e
|
|||
str_val = (*attr)->def;
|
||||
}
|
||||
if (str_val) {
|
||||
zval zstr;
|
||||
xmlNodePtr dummy;
|
||||
zval *data;
|
||||
|
||||
dummy = xmlNewNode(NULL, "BOGUS");
|
||||
xmlNodeSetContent(dummy, str_val);
|
||||
ZVAL_STRING(&zstr, str_val, 0);
|
||||
dummy = master_to_xml(get_conversion(IS_STRING), &zstr, SOAP_LITERAL, NULL);
|
||||
data = master_to_zval((*attr)->encode, dummy);
|
||||
xmlFreeNode(dummy);
|
||||
set_zval_property(ret, (*attr)->name, data TSRMLS_CC);
|
||||
|
|
40
ext/soap/tests/bugs/bug38004.phpt
Executable file
40
ext/soap/tests/bugs/bug38004.phpt
Executable file
|
@ -0,0 +1,40 @@
|
|||
--TEST--
|
||||
Bug #37278 (SOAP not respecting uri in __soapCall)
|
||||
--SKIPIF--
|
||||
<?php require_once('skipif.inc'); ?>
|
||||
--FILE--
|
||||
<?php
|
||||
function Test($param) {
|
||||
global $g;
|
||||
$g = $param->strA."\n".$param->strB."\n";
|
||||
return $g;
|
||||
}
|
||||
|
||||
class TestSoapClient extends SoapClient {
|
||||
function __construct($wsdl) {
|
||||
parent::__construct($wsdl);
|
||||
$this->server = new SoapServer($wsdl);
|
||||
$this->server->addFunction('Test');
|
||||
}
|
||||
|
||||
function __doRequest($request, $location, $action, $version) {
|
||||
ob_start();
|
||||
$this->server->handle($request);
|
||||
$response = ob_get_contents();
|
||||
ob_end_clean();
|
||||
return $response;
|
||||
}
|
||||
}
|
||||
|
||||
$client = new TestSoapClient(dirname(__FILE__).'/bug38004.wsdl');
|
||||
$strA = 'test & test';
|
||||
$strB = 'test & test';
|
||||
$res = $client->Test(array('strA'=>$strA, 'strB'=>$strB));
|
||||
print_r($res);
|
||||
print_r($g);
|
||||
?>
|
||||
--EXPECT--
|
||||
test & test
|
||||
test & test
|
||||
test & test
|
||||
test & test
|
51
ext/soap/tests/bugs/bug38004.wsdl
Executable file
51
ext/soap/tests/bugs/bug38004.wsdl
Executable file
|
@ -0,0 +1,51 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<definitions
|
||||
xmlns:http="http://schemas.xmlsoap.org/wsdl/http/"
|
||||
xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
|
||||
xmlns:s="http://www.w3.org/2001/XMLSchema"
|
||||
xmlns:s0="http://test.pl"
|
||||
targetNamespace="http://test.pl"
|
||||
xmlns="http://schemas.xmlsoap.org/wsdl/"
|
||||
>
|
||||
<types>
|
||||
<s:schema elementFormDefault="qualified" targetNamespace="http://test.pl">
|
||||
<s:complexType name="Test">
|
||||
<s:attribute use="required" name="strA" type="s:string"/>
|
||||
<s:attribute use="required" name="strB" type="s:string"/>
|
||||
</s:complexType>
|
||||
<s:element type="s0:Test" name="Test"/>
|
||||
<s:element type="s:string" name="Ret"/>
|
||||
</s:schema>
|
||||
</types>
|
||||
|
||||
<message name="TestSoapIn">
|
||||
<part name="parameters" element="s0:Test"/>
|
||||
</message>
|
||||
<message name="TestSoapOut">
|
||||
<part name="parameters" element="s0:Ret"/>
|
||||
</message>
|
||||
<portType name="TestSoap">
|
||||
<operation name="Test">
|
||||
<input message="s0:TestSoapIn"/>
|
||||
<output message="s0:TestSoapOut"/>
|
||||
</operation>
|
||||
</portType>
|
||||
<binding name="TestSoap" type="s0:TestSoap">
|
||||
<soap:binding transport="http://schemas.xmlsoap.org/soap/http"
|
||||
style="document"/>
|
||||
<operation name="Test">
|
||||
<soap:operation soapAction="http:/Test/Test" style="document"/>
|
||||
<input>
|
||||
<soap:body use="literal"/>
|
||||
</input>
|
||||
<output>
|
||||
<soap:body use="literal"/>
|
||||
</output>
|
||||
</operation>
|
||||
</binding>
|
||||
<service name="Test">
|
||||
<port name="TestSoapPort" binding="s0:TestSoap">
|
||||
<soap:address location="http://localhost:8080/~dmitry/bug38004/server.php"/>
|
||||
</port>
|
||||
</service>
|
||||
</definitions>
|
Loading…
Add table
Add a link
Reference in a new issue