Fixed bug #38004 Parameters in SoapServer are decoded twice

This commit is contained in:
Dmitry Stogov 2006-07-10 07:21:41 +00:00
parent f66cd50510
commit c389a653f7
4 changed files with 95 additions and 2 deletions

1
NEWS
View file

@ -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)

View file

@ -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);

View 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 &amp; test';
$strB = 'test & test';
$res = $client->Test(array('strA'=>$strA, 'strB'=>$strB));
print_r($res);
print_r($g);
?>
--EXPECT--
test &amp; test
test & test
test &amp; test
test & test

View 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>