Course Name - PHP
Data Types and Operators
Global Variables - Superglobals
Superglobals were introduced in PHP 4.1.0, and are built-in variables that are always available in all scopes.
PHP Global Variables - Superglobals
Several predefined variables in PHP are "superglobals", which means that they are always accessible, regardless of scope - and you can access them from any function, class or file without having to do anything special.
The PHP superglobal variables are:
- $GLOBALS
- $_SERVER
- $_REQUEST
- $_POST
- $_GET
- $_FILES
- $_ENV
- $_COOKIE
- $_SESSION
This chapter will explain some of the superglobals, and the rest will be explained in later chapters.
PHP $GLOBALS
$GLOBALS is a PHP super global variable which is used to access global variables from anywhere in the PHP script (also from within functions or methods).
PHP stores all global variables in an array called $GLOBALS[index]. The index holds the name of the variable.
The example below shows how to use the super global variable $GLOBALS:
Example
                            <?php 
$x = 75; 
$y = 25;
 
function addition() { 
    $GLOBALS['z'] = $GLOBALS['x'] + $GLOBALS['y']; 
}
 
addition(); 
echo $z; 
?>
                        
                    In the example above, since z is a variable present within the $GLOBALS array, it is also accessible from outside the function!
PHP $_SERVER
$_SERVER is a PHP super global variable which holds information about headers, paths, and script locations.
The example below shows how to use some of the elements in $_SERVER:
Example
                            
                                <?php 
echo $_SERVER['PHP_SELF'];
echo "<br>";
                                 echo $_SERVER['SERVER_NAME'];
echo "<br>";
echo $_SERVER['HTTP_HOST'];
                                 echo "<br>";
echo $_SERVER['HTTP_REFERER'];
echo "<br>";
echo $_SERVER['HTTP_USER_AGENT'];
echo "<br>";
echo $_SERVER['SCRIPT_NAME'];
?>
                            
                        
                    The following table lists the most important elements that can go inside $_SERVER:
| Element/Code | Description | 
|---|---|
| $_SERVER['PHP_SELF'] | Returns the filename of the currently executing script | 
| $_SERVER['GATEWAY_INTERFACE'] | Returns the version of the Common Gateway Interface (CGI) the server is using | 
| $_SERVER['SERVER_ADDR'] | Returns the IP address of the host server | 
| $_SERVER['SERVER_NAME'] | Returns the name of the host server (such as www.w3schools.com) | 
| $_SERVER['SERVER_SOFTWARE'] | Returns the server identification string (such as Apache/2.2.24) | 
| $_SERVER['SERVER_PROTOCOL'] | Returns the name and revision of the information protocol (such as HTTP/1.1) | 
| $_SERVER['REQUEST_METHOD'] | Returns the request method used to access the page (such as POST) | 
| $_SERVER['REQUEST_TIME'] | Returns the timestamp of the start of the request (such as 1377687496) | 
| $_SERVER['QUERY_STRING'] | Returns the query string if the page is accessed via a query string | 
| $_SERVER['HTTP_ACCEPT'] | Returns the Accept header from the current request | 
| $_SERVER['HTTP_ACCEPT_CHARSET'] | Returns the Accept_Charset header from the current request (such as utf-8,ISO-8859-1) | 
| $_SERVER['HTTP_HOST'] | Returns the Host header from the current request | 
| $_SERVER['HTTP_REFERER'] | Returns the complete URL of the current page (not reliable because not all user-agents support it) | 
| $_SERVER['HTTPS'] | Is the script queried through a secure HTTP protocol | 
| $_SERVER['REMOTE_ADDR'] | Returns the IP address from where the user is viewing the current page | 
| $_SERVER['REMOTE_HOST'] | Returns the Host name from where the user is viewing the current page | 
| $_SERVER['REMOTE_PORT'] | Returns the port being used on the user's machine to communicate with the web server | 
| $_SERVER['SCRIPT_FILENAME'] | Returns the absolute pathname of the currently executing script | 
| $_SERVER['SERVER_ADMIN'] | Returns the value given to the SERVER_ADMIN directive in the web server configuration file (if your script runs on a virtual host, it will be the value defined for that virtual host) (such as someone@w3schools.com) | 
| $_SERVER['SERVER_PORT'] | Returns the port on the server machine being used by the web server for communication (such as 80) | 
| $_SERVER['SERVER_SIGNATURE'] | Returns the server version and virtual host name which are added to server-generated pages | 
| $_SERVER['PATH_TRANSLATED'] | Returns the file system based path to the current script | 
| $_SERVER['SCRIPT_NAME'] | Returns the path of the current script | 
| $_SERVER['SCRIPT_URI'] | Returns the URI of the current page | 
PHP $_REQUEST
PHP $_REQUEST is used to collect data after submitting an HTML form.
The example below shows a form with an input field and a submit button. When a user submits the data by clicking on "Submit", the form data is sent to the file specified in the action attribute of the <form> tag. In this example, we point to this file itself for processing form data. If you wish to use another PHP file to process form data, replace that with the filename of your choice. Then, we can use the super global variable $_REQUEST to collect the value of the input field:
Example
                            <html>
                            <body>
                            
                            <form method="post" action="<?php echo $_SERVER['PHP_SELF'];?>">
  Name: <input type="text" name="fname">
  <input type="submit">
                            </form>
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
    // collect value of input field
    $name = $_REQUEST['fname'];
    if (empty($name)) {
        echo "Name is empty";
    } else {
        echo $name;
    }
}
?>
                            
                            </body>
                            </html>
                        
                    PHP $_POST
PHP $_POST is widely used to collect form data after submitting an HTML form with method="post". $_POST is also widely used to pass variables.
The example below shows a form with an input field and a submit button. When a user submits the data by clicking on "Submit", the form data is sent to the file specified in the action attribute of the <form> tag. In this example, we point to the file itself for processing form data. If you wish to use another PHP file to process form data, replace that with the filename of your choice. Then, we can use the super global variable $_POST to collect the value of the input field:
Example
                            <html>
                            <body>
                            
                            <form method="post" action="<?php echo $_SERVER['PHP_SELF'];?>">
  Name: <input type="text" name="fname">
  <input type="submit">
                            </form>
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
    // collect value of input field
    $name = $_POST['fname'];
    if (empty($name)) {
        echo "Name is empty";
    } else {
        echo $name;
    }
}
?>
                            
                            </body>
                            </html>
                        
                    PHP $_GET
PHP $_GET can also be used to collect form data after submitting an HTML form with method="get".
$_GET can also collect data sent in the URL.
Assume we have an HTML page that contains a hyperlink with parameters:
                        
                            <html>
                            <body>
                            <a href="test_get.php?subject=PHP&web=W3schools.com">Test $GET</a>
                            </body>
                            </html>
                        
                    
                    When a user clicks on the link "Test $GET", the parameters "subject" and "web" are sent to "test_get.php", and you can then access their values in "test_get.php" with $_GET.
The example below shows the code in "test_get.php":
Example
                            <html>
                            <body>
                            
                            <?php 
echo "Study " . $_GET['subject'] . " at " . $_GET['web'];
?>
                            
                            </body>
                            </html>
                        
                    PHP Form Handling
The PHP superglobals $_GET and $_POST are used to collect form-data.
PHP - A Simple HTML Form
The example below displays a simple HTML form with two input fields and a submit button:
Example
                            <html>
                            <body>
                            
                            <form action="welcome.php" method="post">
                            Name: <input type="text" name="name"><br>
                            E-mail: <input type="text" name="email"><br>
                            <input type="submit">
                            </form>
                            
                            </body>
                            </html>
                        
                    When the user fills out the form above and clicks the submit button, the form data is sent for processing to a PHP file named "welcome.php". The form data is sent with the HTTP POST method.
To display the submitted data you could simply echo all the variables. The "welcome.php" looks like this:
                        
                            <html>
                            <body>
                            
                            Welcome <?php echo $_POST["name"]; ?><br>
                            Your email address is: <?php echo $_POST["email"]; ?>
                            
                            </body>
                            </html>
                        
                    
                    The output could be something like this:
                        
                            Welcome John
                            Your email address is john.doe@example.com
                        
                    
                    The same result could also be achieved using the HTTP GET method:
Example
                            <html>
                            <body>
                            
                            <form action="welcome_get.php" method="get">
                            Name: <input type="text" name="name"><br>
                            E-mail: <input type="text" name="email"><br>
                            <input type="submit">
                            </form>
                            
                            </body>
                            </html>
                        
                    and "welcome_get.php" looks like this:
                        
                            <html>
                            <body>
                            
                            Welcome <?php echo $_GET["name"]; ?><br>
                            Your email address is: <?php echo $_GET["email"]; ?>
                            
                            </body>
                            </html>
                        
                    
                    The code above is quite simple. However, the most important thing is missing. You need to validate form data to protect your script from malicious code.
Think SECURITY when processing PHP forms!
This page does not contain any form validation, it just shows how you can send and retrieve form data.
However, the next pages will show how to process PHP forms with security in mind! Proper validation of form data is important to protect your form from hackers and spammers!
GET vs. POST
Both GET and POST create an array (e.g. array( key => value, key2 => value2, key3 => value3, ...)). This array holds key/value pairs, where keys are the names of the form controls and values are the input data from the user.
Both GET and POST are treated as $_GET and $_POST. These are superglobals, which means that they are always accessible, regardless of scope - and you can access them from any function, class or file without having to do anything special.
$_GET is an array of variables passed to the current script via the URL parameters.
$_POST is an array of variables passed to the current script via the HTTP POST method.
When to use GET?
Information sent from a form with the GET method is visible to everyone (all variable names and values are displayed in the URL). GET also has limits on the amount of information to send. The limitation is about 2000 characters. However, because the variables are displayed in the URL, it is possible to bookmark the page. This can be useful in some cases.
GET may be used for sending non-sensitive data.
Note: GET should NEVER be used for sending passwords or other sensitive information!
When to use POST?
Information sent from a form with the POST method is invisible to others (all names/values are embedded within the body of the HTTP request) and has no limits on the amount of information to send.
Moreover POST supports advanced functionality such as support for multi-part binary input while uploading files to server.
However, because the variables are not displayed in the URL, it is not possible to bookmark the page.
Developers prefer POST for sending form data.







