diff options
| author | Adam Harvey <aharvey@php.net> | 2013-11-10 15:43:56 -0500 | 
|---|---|---|
| committer | Adam Harvey <aharvey@php.net> | 2013-11-10 15:43:56 -0500 | 
| commit | 288e9c642375663cd6eb232ad1b236df912e787e (patch) | |
| tree | 63b5cacf02a1be50bd96a5eef0f4a4dd2ee22e2d /ext/json/json.c | |
| parent | 064ba179b15bda7566fa43297e2cee8033bc850f (diff) | |
| parent | 872ef919ca665d632d55410ef2ff066659af4769 (diff) | |
| download | php-git-288e9c642375663cd6eb232ad1b236df912e787e.tar.gz | |
Merge remote-tracking branch 'ajf/JSONWhitespaceFix' into PHP-5.4
Diffstat (limited to 'ext/json/json.c')
| -rw-r--r-- | ext/json/json.c | 30 | 
1 files changed, 22 insertions, 8 deletions
| diff --git a/ext/json/json.c b/ext/json/json.c index 8c8963db8c..a786fef45c 100644 --- a/ext/json/json.c +++ b/ext/json/json.c @@ -684,21 +684,35 @@ PHP_JSON_API void php_json_decode_ex(zval *return_value, char *str, int str_len,  		double d;  		int type, overflow_info;  		long p; +		char *trim = str; +		int trim_len = str_len; + +		/* Increment trimmed string pointer to strip leading whitespace */ +		/* JSON RFC says to consider as whitespace: space, tab, LF or CR */ +		while (trim_len && (*trim == ' ' || *trim == '\t' || *trim == '\n' || *trim == '\r')) { +			trim++; +			trim_len--; +		} + +		/* Decrement trimmed string length to strip trailing whitespace */ +		while (trim_len && (trim[trim_len - 1] == ' ' || trim[trim_len - 1] == '\t' || trim[trim_len - 1] == '\n' || trim[trim_len - 1] == '\r')) { +			trim_len--; +		}  		RETVAL_NULL(); -		if (str_len == 4) { -			if (!strcasecmp(str, "null")) { +		if (trim_len == 4) { +			if (!strncasecmp(trim, "null", trim_len)) {  				/* We need to explicitly clear the error because its an actual NULL and not an error */  				jp->error_code = PHP_JSON_ERROR_NONE;  				RETVAL_NULL(); -			} else if (!strcasecmp(str, "true")) { +			} else if (!strncasecmp(trim, "true", trim_len)) {  				RETVAL_BOOL(1);  			} -		} else if (str_len == 5 && !strcasecmp(str, "false")) { +		} else if (trim_len == 5 && !strncasecmp(trim, "false", trim_len)) {  			RETVAL_BOOL(0);  		} -		if ((type = is_numeric_string_ex(str, str_len, &p, &d, 0, &overflow_info)) != 0) { +		if ((type = is_numeric_string_ex(trim, trim_len, &p, &d, 0, &overflow_info)) != 0) {  			if (type == IS_LONG) {  				RETVAL_LONG(p);  			} else if (type == IS_DOUBLE) { @@ -711,10 +725,10 @@ PHP_JSON_API void php_json_decode_ex(zval *return_value, char *str, int str_len,  					int i;  					zend_bool is_float = 0; -					for (i = (str[0] == '-' ? 1 : 0); i < str_len; i++) { +					for (i = (trim[0] == '-' ? 1 : 0); i < trim_len; i++) {  						/* Not using isdigit() because it's locale specific,  						 * but we expect JSON input to always be UTF-8. */ -						if (str[i] < '0' || str[i] > '9') { +						if (trim[i] < '0' || trim[i] > '9') {  							is_float = 1;  							break;  						} @@ -723,7 +737,7 @@ PHP_JSON_API void php_json_decode_ex(zval *return_value, char *str, int str_len,  					if (is_float) {  						RETVAL_DOUBLE(d);  					} else { -						RETVAL_STRINGL(str, str_len, 1); +						RETVAL_STRINGL(trim, trim_len, 1);  					}  				} else {  					RETVAL_DOUBLE(d); | 
