diff options
author | Rasmus Lerdorf <rasmus@php.net> | 2012-05-03 15:51:52 +0200 |
---|---|---|
committer | Stanislav Malyshev <stas@php.net> | 2012-05-07 12:06:45 -0700 |
commit | 004941af15674eeb5d12b8459b8ff50c25758150 (patch) | |
tree | 3f4fab28405234b4601278fbcf30f22e5bd613ef /sapi/cgi/cgi_main.c | |
parent | 72507d38fb6701471053ef6bee65dfbe63184ec9 (diff) | |
download | php-git-004941af15674eeb5d12b8459b8ff50c25758150.tar.gz |
Fix for CVE-2012-1823
Diffstat (limited to 'sapi/cgi/cgi_main.c')
-rw-r--r-- | sapi/cgi/cgi_main.c | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/sapi/cgi/cgi_main.c b/sapi/cgi/cgi_main.c index 56c736f5cc..760ad668e1 100644 --- a/sapi/cgi/cgi_main.c +++ b/sapi/cgi/cgi_main.c @@ -70,6 +70,7 @@ #include "php_main.h" #include "fopen_wrappers.h" #include "ext/standard/php_standard.h" +#include "ext/standard/url.h" #ifdef PHP_WIN32 # include <io.h> @@ -1508,6 +1509,9 @@ int main(int argc, char *argv[]) #ifndef PHP_WIN32 int status = 0; #endif + char *query_string; + char *decoded_query_string; + int skip_getopt = 0; #if 0 && defined(PHP_DEBUG) /* IIS is always making things more difficult. This allows @@ -1557,7 +1561,16 @@ int main(int argc, char *argv[]) } } - while ((c = php_getopt(argc, argv, OPTIONS, &php_optarg, &php_optind, 0, 2)) != -1) { + if(query_string = getenv("QUERY_STRING")) { + decoded_query_string = strdup(query_string); + php_url_decode(decoded_query_string, strlen(decoded_query_string)); + if(*decoded_query_string == '-' && strchr(decoded_query_string, '=') == NULL) { + skip_getopt = 1; + } + free(decoded_query_string); + } + + while (!skip_getopt && (c = php_getopt(argc, argv, OPTIONS, &php_optarg, &php_optind, 0, 2)) != -1) { switch (c) { case 'c': if (cgi_sapi_module.php_ini_path_override) { |