How To Identify The Requested Page In PHP

后端 未结 5 1451
栀梦
栀梦 2021-02-04 04:59

Is there any easy way to identify the file initially handling the request, ignoring get arguments and handling (at least basic) mappings like / to /index.php<

5条回答
  •  自闭症患者
    2021-02-04 05:37

    I decided to test it out myself. The $_SERVER['SCRIPT_NAME'] variable serves up the path to the requested file, even if it's an index file, and without get parameters or anything else. The PHP documentation states this contains the path of the file, but it seems to be relative to the document root, just like PHP_SELF, but without the security vulnerability.

    Here is the code I used to test this: https://gist.github.com/dimo414/5484870

    The output when requesting example.com/?foo=bar:

    __FILE__:               /var/www/index.php
    PHP_SELF:               /index.php
    SCRIPT_NAME:            /index.php
    REQUEST_URI:            /?foo=bar
    parse_url(REQUEST_URI): /
    
    
    __FILE__:               /var/www/pathtest.php
    PHP_SELF:               /index.php
    SCRIPT_NAME:            /index.php
    REQUEST_URI:            /?foo=bar
    parse_url(REQUEST_URI): /
    

    And the output when requesting example.com/index.php/XSS:

    __FILE__:               /var/www/index.php
    PHP_SELF:               /index.php/XSS # note the XSS exploit (this is bold in browser)
    SCRIPT_NAME:            /index.php     # No exploit here
    REQUEST_URI:            /index.php/%3Cstrong%3EXSS%3C/strong%3E
    parse_url(REQUEST_URI): /index.php/%3Cstrong%3EXSS%3C/strong%3E
    
    
    __FILE__:               /var/www/pathtest.php
    PHP_SELF:               /index.php/XSS
    SCRIPT_NAME:            /index.php
    REQUEST_URI:            /index.php/%3Cstrong%3EXSS%3C/strong%3E
    parse_url(REQUEST_URI): /index.php/%3Cstrong%3EXSS%3C/strong%3E
    

    As you can see, $_SERVER['SCRIPT_NAME'] always gives back the file that originally handled the request, i.e. the file in the URL, without any XSS risks.

提交回复
热议问题