ID:               9434
 Updated by:       [EMAIL PROTECTED]
 Reported By:      sagawa at sohgoh dot net
-Status:           Critical
+Status:           Closed
 Bug Type:         *General Issues
 Operating System: Any
-PHP Version:      CVS
+PHP Version:      4.0.4
 New Comment:

Fixed in current versions. (this was forgotten after all, due to a bug
in our bug system :)



Previous Comments:
------------------------------------------------------------------------

[2002-06-15 19:29:19] [EMAIL PROTECTED]

let's make it critical so it's not forgotten.
(hopefully)


------------------------------------------------------------------------

[2002-06-15 10:13:20] [EMAIL PROTECTED]

This issue is still valid and should be addressed before 4.3.0:

C:\php\latest>type test.php
<?
        echo "\$_GET: \n";
        var_dump($_GET);
        echo "\n\$argv: \n";
        var_dump($_SERVER['argv']);
?>

C:\php\latest>php-cgi -v
PHP 4.3.0-dev (cgi), Copyright (c) 1997-2002 The PHP Group
Zend Engine v1.2.1, Copyright (c) 1998-2002 Zend Technologies

C:\php\latest>php-cgi -f test.php "a=1" "b=2" "c=3&d=4"
$_GET:
array(2) {
  ["test_php_a"]=>
  string(9) "1 b=2 c=3"
  ["d"]=>
  string(1) "4"
}

$argv:
array(4) {
  [0]=>
  string(8) "test.php"
  [1]=>
  string(3) "a=1"
  [2]=>
  string(3) "b=2"
  [3]=>
  string(7) "c=3&d=4"
}

Obviously, the "test_php_a" entry in $_GET is wrong. This is because
internal this is translated to "test.php?a=1" and since "." and "?" are
not allowed in variable names they're converted to "_". The patch above
is not sufficient.

A few things have to be considered for consistence: the
$_SERVER['argv'] should always containt the right parameters too (i.e.
if someone fixed the $_GET issue, $_SERVER['argv'] should still work.
If you take a look at the source (cgi_main.c and main/main.c in
php_build_argv you'll soon see what I mean).

The purpose of this is to have the ability to run CGI written scripts
from the shell and be able to pass the same GET request to the script.

------------------------------------------------------------------------

[2001-03-15 12:22:43] sagawa at sohgoh dot net

I withdraw this patch. Because, it turns out that this patch
have a bad influence on argument variables. All argvs are
connected to only argv[0], so we can't get argv[2] and so on.
I am thankful to Mr.Hirokawa who pointed out this.


------------------------------------------------------------------------

[2001-02-24 04:33:33] sagawa at sohgoh dot net

I get funny $HTTP_GET_VARS passed by command line argument
query_string,
on PHP 4.0.4(as far as I know :) with cgi-sapi.

This is sample for this problem.
test.php is <?php var_dump($HTTP_GET_VARS); ?>
and run from command line.

% php -f test.php 'AAA=xx&BB=yy' 'CC=zz'
array(2) {
  ["test_php_AAA"]=>
  string(2) "xx"
  ["BB"]=>
  string(8) "yy CC=zz"
}

`AAA' is connected with file name,
and inserted space between arguments.
(test.php was changed to test_php because of php variable
name restriction.)

So, I modify sapi/cgi/cgi_main.c.
% diff -u cgi_main.c~ cgi_main.c
--- cgi_main.c~ Sun Dec  3 10:09:13 2000
+++ cgi_main.c  Thu Feb 22 21:20:47 2001
@@ -649,14 +649,10 @@

                        s = malloc(len + 1);    /* leak -
but only for command line version, so ok */
                        *s = '\0';                      /*
we are pretending it came from the environment  */
-                       if (script_file) {
-                               strcpy(s, script_file);
-                               strcat(s, "+");
-                       }
                        for (i = ap_php_optind, len = 0; i <
argc; i++) {
                                strcat(s, argv[i]);
                                if (i < (argc - 1)) {
-                                       strcat(s, "+");
+                                       strcat(s,
PG(arg_separator));
                                }
                        }
                        SG(request_info).query_string = s;

This works fine, like...
% php -f test.php 'AAA=xx&BB=yy' 'CC=zz'
array(3) {
  ["AAA"]=>
  string(2) "xx"
  ["BB"]=>
  string(2) "yy"
  ["CC"]=>
  string(2) "zz"
} 


------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=9434&edit=1

Reply via email to