diff options
Diffstat (limited to 'ext/soap/php_encoding.c')
| -rw-r--r-- | ext/soap/php_encoding.c | 21 | 
1 files changed, 14 insertions, 7 deletions
| diff --git a/ext/soap/php_encoding.c b/ext/soap/php_encoding.c index 20502e5a55..dd557a7950 100644 --- a/ext/soap/php_encoding.c +++ b/ext/soap/php_encoding.c @@ -402,12 +402,15 @@ static xmlNodePtr master_to_xml_int(encodePtr encode, zval *data, int style, xml  		encodePtr enc = NULL;  		HashTable *ht = Z_OBJPROP_P(data); -		if (zend_hash_find(ht, "enc_type", sizeof("enc_type"), (void **)&ztype) == FAILURE) { +		if (zend_hash_find(ht, "enc_type", sizeof("enc_type"), (void **)&ztype) == FAILURE || +		    Z_TYPE_PP(ztype) != IS_LONG) {  			soap_error0(E_ERROR, "Encoding: SoapVar has no 'enc_type' property");  		} -		if (zend_hash_find(ht, "enc_stype", sizeof("enc_stype"), (void **)&zstype) == SUCCESS) { -			if (zend_hash_find(ht, "enc_ns", sizeof("enc_ns"), (void **)&zns) == SUCCESS) { +		if (zend_hash_find(ht, "enc_stype", sizeof("enc_stype"), (void **)&zstype) == SUCCESS && +		    Z_TYPE_PP(zstype) == IS_STRING) { +			if (zend_hash_find(ht, "enc_ns", sizeof("enc_ns"), (void **)&zns) == SUCCESS && +			    Z_TYPE_PP(zns) == IS_STRING) {  				enc = get_encoder(SOAP_GLOBAL(sdl), Z_STRVAL_PP(zns), Z_STRVAL_PP(zstype));  			} else {  				zns = NULL; @@ -443,8 +446,10 @@ static xmlNodePtr master_to_xml_int(encodePtr encode, zval *data, int style, xml  		}  		if (style == SOAP_ENCODED || (SOAP_GLOBAL(sdl) && encode != enc)) { -			if (zend_hash_find(ht, "enc_stype", sizeof("enc_stype"), (void **)&zstype) == SUCCESS) { -				if (zend_hash_find(ht, "enc_ns", sizeof("enc_ns"), (void **)&zns) == SUCCESS) { +			if (zend_hash_find(ht, "enc_stype", sizeof("enc_stype"), (void **)&zstype) == SUCCESS && +			    Z_TYPE_PP(zstype) == IS_STRING) { +				if (zend_hash_find(ht, "enc_ns", sizeof("enc_ns"), (void **)&zns) == SUCCESS && +				    Z_TYPE_PP(zns) == IS_STRING) {  					set_ns_and_type_ex(node, Z_STRVAL_PP(zns), Z_STRVAL_PP(zstype));  				} else {  					set_ns_and_type_ex(node, NULL, Z_STRVAL_PP(zstype)); @@ -452,10 +457,12 @@ static xmlNodePtr master_to_xml_int(encodePtr encode, zval *data, int style, xml  			}  		} -		if (zend_hash_find(ht, "enc_name", sizeof("enc_name"), (void **)&zname) == SUCCESS) { +		if (zend_hash_find(ht, "enc_name", sizeof("enc_name"), (void **)&zname) == SUCCESS && +		    Z_TYPE_PP(zname) == IS_STRING) {  			xmlNodeSetName(node, BAD_CAST(Z_STRVAL_PP(zname)));  		} -		if (zend_hash_find(ht, "enc_namens", sizeof("enc_namens"), (void **)&znamens) == SUCCESS) { +		if (zend_hash_find(ht, "enc_namens", sizeof("enc_namens"), (void **)&znamens) == SUCCESS && +		    Z_TYPE_PP(zname) == IS_STRING) {  			xmlNsPtr nsp = encode_add_ns(node, Z_STRVAL_PP(znamens));  			xmlSetNs(node, nsp);  		} | 
