From: Dmitry Stogov Date: Wed, 17 Oct 2007 12:08:46 +0000 (+0000) Subject: Fixed possible crash because of uninitialized value (Zdash Urf) X-Git-Tag: php-5.2.5RC1~8 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=c43fe1c6cf0a4b7904954254eb4219e887771641;p=php Fixed possible crash because of uninitialized value (Zdash Urf) --- diff --git a/NEWS b/NEWS index 3d3f837a4c..0515536b33 100644 --- a/NEWS +++ b/NEWS @@ -9,6 +9,7 @@ PHP NEWS array_uintersect_assoc(), array_diff_key(), array_diff_assoc() and array_udiff_assoc(). (Dmitry) +- Fixed possible crash in ext/soap because of uninitialized value. (Zdash Urf) - Fixed regression in glob() when enforcing safe_mode/open_basedir checks on paths containing '*'. (Ilia) - Fixed "mail.force_extra_parameters" php.ini directive not to be modifiable diff --git a/ext/soap/php_encoding.c b/ext/soap/php_encoding.c index 8354f87ace..264e648bbf 100644 --- a/ext/soap/php_encoding.c +++ b/ext/soap/php_encoding.c @@ -1208,9 +1208,10 @@ static zval* get_zval_property(zval* object, char* name TSRMLS_DC) zval *data; zend_class_entry *old_scope; + INIT_PZVAL(&member); ZVAL_STRING(&member, name, 0); old_scope = EG(scope); - EG(scope) = Z_OBJCE_P(object); + EG(scope) = Z_OBJCE_P(object); data = Z_OBJ_HT_P(object)->read_property(object, &member, BP_VAR_IS TSRMLS_CC); if (data == EG(uninitialized_zval_ptr)) { /* Hack for bug #32455 */ @@ -1241,9 +1242,10 @@ static void unset_zval_property(zval* object, char* name TSRMLS_DC) zval member; zend_class_entry *old_scope; + INIT_PZVAL(&member); ZVAL_STRING(&member, name, 0); old_scope = EG(scope); - EG(scope) = Z_OBJCE_P(object); + EG(scope) = Z_OBJCE_P(object); Z_OBJ_HT_P(object)->unset_property(object, &member TSRMLS_CC); EG(scope) = old_scope; } else if (Z_TYPE_P(object) == IS_ARRAY) { diff --git a/ext/soap/tests/classmap004.phpt b/ext/soap/tests/classmap004.phpt new file mode 100755 index 0000000000..3b9d678e6a --- /dev/null +++ b/ext/soap/tests/classmap004.phpt @@ -0,0 +1,66 @@ +--TEST-- +SOAP Classmap 4: encoding of objects with __get() +--SKIPIF-- + +--FILE-- +x = $a; + } + function __get($name) { + return @$this->a[$name]; + } + function __set($name, $val) { + $this->a[$name] = $val; + } + function __unset($name) { + unset($this->a[$name]); + } +} + +class B extends A { + function __construct($a){ + parent::__construct($a); + $this->y = $a + 1; + } +} + +function f(){ + return new B(5); +} + +class LocalSoapClient extends SoapClient { + + function __construct($wsdl, $options) { + parent::__construct($wsdl, $options); + $this->server = new SoapServer($wsdl, $options); + $this->server->addFunction("f"); + } + + function __doRequest($request, $location, $action, $version) { + ob_start(); + $this->server->handle($request); + $response = ob_get_contents(); + ob_end_clean(); + return $response; + } +} + +$client = new LocalSoapClient(dirname(__FILE__)."/classmap003.wsdl", + array('classmap'=>array('A'=>'A','B'=>'B'))); +print_r($client->f()); +?> +--EXPECT-- +B Object +( + [a] => Array + ( + [x] => 5 + [y] => 6 + ) + +)