Welcome to PHP
PHP: Hypertext Preprocessor (PHP) is a free, highly popular, open source scripting
language. PHP scripts are executed on the server.
Just a short list of what PHP is capable of:
- Generating dynamic page content
- Creating, opening, reading, writing, deleting, and closing files on the server
- Collecting form data
- Adding, deleting, and modifying information stored in your database
- controlling user-access
- encrypting data
- and much more!
Before starting this tutorial, you should have a basic understanding of HTML.
Why PHP
PHP runs on numerous, varying platforms, including Windows, Linux, Unix, Mac OS X,
and so on.
PHP is compatible with almost any modern server, such as Apache, IIS, and more.
PHP supports a wide range of databases.
PHP is free!
PHP Syntax
A PHP script starts with <?php and ends with ?>:
Here is an example of a simple PHP file. The PHP script uses a built in function called "echo" to
output the text "Hello World!" to a web page.
<html>
<head>
<title>My First PHP Page</title>
</head>
<body>
<?php
echo "Hello World!";
?>
</body>
</html>
Result:
PHP Syntax
Alternatively, we can include PHP in the HTML <script> tag.
PHP Syntax
You can also use the shorthand PHP tags, <? ?>, as long as they're supported by the
server.
<?
echo "Hello World!";
?>
Result:
Echo
PHP has a built-in "echo" function, which is used to output text.
In actuality, it's not a function; it's a language construct. As such, it does not require
parentheses.
Let's output a text.
<?php
echo "I love PHP!";
?>
Result:
PHP Statements
Each PHP statement must end with a semicolon.
<?php
echo "A";
echo "B";
echo "C";
?>
Result:
Echo
HTML markup can be added to the text in the echo statement.
<?php
echo "<strong>This is a bold text.</strong>";
?>
Result:
Comments
In PHP code, a comment is a line that is not executed as part of the program. You can
use comments to communicate to others so they understand what you're doing, or as a
reminder to yourself of what you did.
A single-line comment starts with //:
<?php
echo "<p>Hello World!</p>";
// This is a single-line comment
echo "<p>I am learning PHP!</p>";
echo "<p>This is my first program!</p>";
?>
Result:
Multi-Line Comments
Multi-line comments are used for composing comments that take more than a single
line.
A multi-line comment begins with /* and ends with */.
<?php
echo "<p>Hello World!</p>";
/*
This is a multi-line comment block
that spans over
multiple lines
*/
echo "<p>I am learning PHP!</p>";
echo "<p>This is my first program!</p>";
?>
Result:
Variables
Variables are used as "containers" in which we store information.
A PHP variable starts with a dollar sign ($), which is followed by the name of the
variable.
Rules for PHP variables:
- A variable name must start with a letter or an underscore
- A variable name cannot start with a number
- A variable name can only contain alpha-numeric characters and underscores (A-z, 0-9, and _ )
- Variable names are case-sensitive ($name and $NAME would be two different variables)
For example:
<?php
$name = 'John';
$age = 25;
echo $name;
?>
Result:
In the example above, notice that we did not have to tell PHP which data type the variable is.
PHP automatically converts the variable to the correct data type, depending on its value.
Constants
Constants are similar to variables except that they cannot be changed or undefined after
they've been defined.
Begin the name of your constant with a letter or an underscore.
To create a constant, use the define() function:
Parameters:
name: Specifies the name of the constant;
value: Specifies the value of the constant;
case-insensitive: Specifies whether the constant name should be case-insensitive. Default
is false;
The example below creates a constant with a case-sensitive name:
<?php
define("MSG", "Hi SoloLearners!");
echo MSG;
?>
Result:
The example below creates a constant with a case-insensitive name:
<?php
define("MSG", " Hi SoloLearners!", true);
echo msg;
?>
Result:
Data Types
Variables can store a variety of data types.
Data types supported by PHP: String, Integer, Float, Boolean, Array, Object, NULL,
Resource.
PHP String
A string is a sequence of characters, like "Hello world!"
A string can be any text within a set of single or double quotes.
PHP Integer
An integer is a whole number (without decimals) that must fit the following criteria:
- It cannot contain commas or blanks
- It must not have a decimal point
- It can be either positive or negative
PHP Float
A float, or floating point number, is a number that includes a decimal point.
PHP Boolean
A Boolean represents two possible states: TRUE or FALSE.
Most of the data types can be used in combination with one another. In this
example, string and integer are put together to determine the sum of two numbers.
<?php
$str = "10";
$int = 20;
$sum = $str + $int;
echo ($sum);
?>
Result:
Variables Scope
PHP variables can be declared anywhere in the script.
The scope of a variable is the part of the script in which the variable can be referenced or
used.
PHP's most used variable scopes are local, global.
A variable declared outside a function has a global scope.
A variable declared within a function has a local scope, and can only be accessed within
that function.
Consider the following example.
<?php
$name = 'David';
function getName() {
echo $name;
getName();
?>
Result:
This script will produce an error, as the $name variable has a global scope, and is not accessible
within the getName() function.
The global Keyword
The global keyword is used to access a global variable from within a function.
To do this, use the global keyword within the function, prior to the variables.
<?php
$name = 'David';
function getName() {
global $name;
echo $name;
getName();
?>
Result:
Variable Variables
With PHP, you can use one variable to specify another variable's name.
So, a variable variable treats the value of another variable as its name.
For example:
<?php
$a = 'hello';
$hello = "Hi!";
echo $$a;
?>
Result:
Arrays
An array is a special variable, which can hold more than one value at a time.
If you have a list of items (a list of names, for example), storing them in single variables
would look like this:
But what if you have 100 names on your list? The solution: Create an array!
Numeric Arrays
Numeric or indexed arrays associate a numeric index with their values.
The index can be assigned automatically (index always starts at 0), like this:
As an alternative, you can assign your index manually.
We defined an array called $names that stores three values.
You can access the array elements through their indices.
<?php
$names = array("David", "Amy", "John");
echo $names[1];
?>
Result:
Numeric Arrays
You can have integers, strings, and other data types together in one array.
Example:
<?php
$myArray[0] = "John";
$myArray[1] = "<strong>PHP</strong>";
$myArray[2] = 21;
echo "$myArray[0] is $myArray[2] and knows $myArray[1]";
?>
Result:
Associative Arrays
Associative arrays are arrays that use named keys that you assign to them.
There are two ways to create an associative array:
Associative Arrays
Use the named keys to access the array's members.
<?php
$people = array("David"=>"27", "Amy"=>"21", "John"=>"42");
echo $people['Amy'];
?>
Result:
Multi-Dimensional Arrays
A multi-dimensional array contains one or more arrays.
The dimension of an array indicates the number of indices you would need to select an
element.
- For a two-dimensional array, you need two indices to select an element
- For a three-dimensional array, you need three indices to select an element
Multi-Dimensional Arrays
Let's create a two-dimensional array that contains 3 arrays:
Now the two-dimensional $people array contains 3 arrays, and it has two
indices: row and column.
To access the elements of the $people array, we must point to the two indices.
<?php
$people = array(
'online'=>array('David', 'Amy'),
'offline'=>array('John', 'Rob', 'Jack'),
'away'=>array('Arthur', 'Daniel')
);
echo $people['online'][0];
echo "<br />";
echo $people['away'][1];
?>
Result:
Conditional Statements
Conditional statements perform different actions for different decisions.
The if else statement is used to execute a certain code if a condition is true, and another
code if the condition is false.
Syntax:
If Else
The example below will output the greatest number of the two.
<?php
$x = 10;
$y = 20;
if ($x >= $y) {
echo $x;
} else {
echo $y;
?>
Result:
The Elseif Statement
Use the if...elseif...else statement to specify a new condition to test, if the first condition
is false.
Syntax:
The Elseif Statement
For example:
<?php
$age = 21;
if ($age<=13) {
echo "Child.";
} elseif ($age>13 && $age<19) {
echo "Teenager";
} else {
echo "Adult";
?>
Result:
Loops
When writing code, you may want the same block of code to run over and over again. Instead of
adding several almost equal code-lines in a script, we can use loops to perform a task like this.
The while Loop
The while loop executes a block of code as long as the specified condition is true.
Syntax:
The while Loop
The example below first sets a variable $i to one ($i = 1). Then, the while loop runs as
long as $i is less than seven ($i < 7). $i will increase by one each time the loop runs
($i++):
<?php
$i = 1;
while ($i < 7) {
echo "The value is $i <br />";
$i++;
?>
Result:
The do...while Loop
The do...while loop will always execute the block of code once, check the condition, and
repeat the loop as long as the specified condition is true.
The do...while Loop
The example below will write some output, and then increment the variable $i by one.
Then the condition is checked, and the loop continues to run, as long as $i is less than or
equal to 7.
<?php
$i = 5;
do {
echo "The number is " . $i . "<br/>";
$i++;
} while($i <= 7);
?>
Result:
The for Loop
The for loop is used when you know in advance how many times the script should run.
Parameters:
init: Initialize the loop counter value
test: Evaluates each time the loop is iterated, continuing if evaluates to true, and ending if it
evaluates to false
increment: Increases the loop counter value
The for Loop
The example below displays the numbers from 0 to 5:
<?php
for ($a = 0; $a < 6; $a++) {
echo "Value of a : ". $a . "<br />";
?>
Result:
The foreach Loop
The foreach loop works only on arrays, and is used to loop through each key/value pair
in an array.
There are two syntaxes:
The first form loops over the array. On each iteration, the value of the current element is assigned
to $value, and the array pointer is moved by one, until it reaches the last array element.
The second form will additionally assign the current element's key to the $key variable on each
iteration.
The following example demonstrates a loop that outputs the values of the $names array.
<?php
$names = array("John", "David", "Amy");
foreach ($names as $name) {
echo $name.'<br />';
?>
Result:
The switch Statement
The switch statement is an alternative to the if-elseif-else statement.
Use the switch statement to select one of a number of blocks of code to be executed.
Syntax:
First, our single expression, n (most often a variable), is evaluated once. Next, the value of the
expression is compared with the value of each case in the structure. If there is a match, the block
of code associated with that case is executed.
Switch
Consider the following example, which displays the appropriate message for each day.
<?php
$today = 'Wed';
switch ($today) {
case "Mon":
echo "Today is Monday.";
break;
case "Tue":
echo "Today is Tuesday.";
break;
case "Wed":
echo "Today is Wednesday.";
break;
case "Thu":
echo "Today is Thursday.";
break;
case "Fri":
echo "Today is Friday.";
break;
case "Sat":
echo "Today is Saturday.";
break;
case "Sun":
echo "Today is Sunday.";
break;
default:
echo "Invalid day.";
?>
Result:
default
The default statement is used if no match is found.
<?php
$x=5;
switch ($x) {
case 1:
echo "One";
break;
case 2:
echo "Two";
break;
default:
echo "No match";
?>
Result:
Switch
Failing to specify the break statement causes PHP to continue to executing the
statements that follow the case, until it finds a break. You can use this behavior if you
need to arrive at the same output for more than one case.
<?php
$day = 'Wed';
switch ($day) {
case 'Mon':
echo 'First day of the week';
break;
case 'Tue':
case 'Wed':
case 'Thu':
echo 'Working day';
break;
case 'Fri':
echo 'Friday!';
break;
default:
echo 'Weekend!';
?>
Result:
The break Statement
As discussed in the previous lesson, the break statement is used to break out of
the switch when a case is matched.
If the break is absent, the code keeps running. For example:
<?php
$x=1;
switch ($x) {
case 1:
echo "One";
case 2:
echo "Two";
case 3:
echo "Three";
default:
echo "No match";
?>
Result:
Break can also be used to halt the execution of for, foreach, while, do-while structures.
The continue Statement
When used within a looping structure, the continue statement allows for skipping over
what remains of the current loop iteration. It then continues the execution at the condition
evaluation and moves on to the beginning of the next iteration.
The following example skips the even numbers in the for loop:
<?php
for ($i=0; $i<10; $i++) {
if ($i%2==0) {
continue;
echo $i . ' ';
?>
Result:
include
The include and require statements allow for the insertion of the content of one PHP file
into another PHP file, before the server executes it.
Including files saves quite a bit of work. You can create a standard header, footer, or
menu file for all of your web pages. Then, when the header is requiring updating, you can
update the header include file only.
Assume that we have a standard header file called header.php.
Use the include statement to include the header file in a page.
include
Using this approach, we have the ability to include the same header.php file into
multiple pages.
Result:
include vs require
The require statement is identical to include, the exception being that, upon failure, it
produces a fatal error.
When a file is included using the include statement, but PHP is unable to find it, the
script continues to execute.
In the case of require, the script will cease execution and produce an error.
Functions
A function is a block of statements that can be used repeatedly in a program.
A function will not execute immediately when a page loads. It will be executed by a call
to the function.
A user defined function declaration starts with the word function:
A function name can start with a letter or an underscore, but not with a number or a special
symbol.
Functions
In the example below, we create the function sayHello(). The opening curly brace ({)
indicates that this is the beginning of the function code, while the closing curly brace (})
indicates that this is the end.
To call the function, just write its name:
<?php
function sayHello() {
echo "Hello!";
sayHello(); //call the function
?>
Result:
Function Parameters
Information can be passed to functions through arguments, which are like variables.
Arguments are specified after the function name, and within the parentheses.
Here, our function takes a number, multiplies it by two, and prints the result:
<?php
function multiplyByTwo($number) {
$answer = $number * 2;
echo $answer;
multiplyByTwo(3);
?>
Result:
You can add as many arguments as you want, as long as they are separated with commas
<?php
function multiply($num1, $num2) {
echo $num1 * $num2;
multiply(3, 6);
?>
Result:
Default Arguments
Default arguments can be defined for the function arguments.
In the example below, we're calling the function setCounter(). There are no arguments,
so it will take on the default values that have been defined.
<?php
function setCounter($num=10) {
echo "Counter is ".$num."<br />";
setCounter(42); //Counter is 42
setCounter(); //Counter is 10
?>
Result:
Return
A function can return a value using the return statement.
Return stops the function's execution, and sends the value back to the calling code.
For example:
<?php
function mult($num1, $num2) {
$res = $num1 * $num2;
return $res;
echo mult(8, 3);
?>
Result:
Predefined Variables
A superglobal is a predefined variable that is always accessible, regardless of scope. You can
access the PHP superglobals through any function, class, or file.
PHP's superglobal variables are $_SERVER, $GLOBALS, $_REQUEST, $_POST, $_GET,
$_FILES, $_ENV, $_COOKIE, $_SESSION.
$_SERVER
$_SERVER is an array that includes information such as headers, paths, and script locations. The
entries in this array are created by the web server.
$_SERVER['SCRIPT_NAME'] returns the path of the current script:
<?php
echo $_SERVER['SCRIPT_NAME'];
?>
Result:
$_SERVER
$_SERVER['HTTP_HOST'] returns the Host header from the current request.
This method can be useful when you have a lot of images on your server and need to transfer the
website to another host. Instead of changing the path for each image, you can do the following:
Create a config.php file, that holds the path to your images:
Use the config.php file in your scripts:
This graphic shows the main elements of $_SERVER.
Forms
The purpose of the PHP superglobals $_GET and $_POST is to collect data that has
been entered into a form.
The example below shows a simple HTML form that includes two input fields and a
submit button:
Result:
Forms
The action attribute specifies that when the form is submitted, the data is sent to a PHP
file named first.php.
HTML form elements have names, which will be used when accessing the data with
PHP.
Forms
Now, when we have an HTML form with the action attribute set to our PHP file, we can
access the posted form data using the $_POST associative array.
In the first.php file:
The $_POST superglobal array holds key/value pairs. In the pairs, keys are the names of the
form controls and values are the input data entered by the user.
POST
The two methods for submitting forms are GET and POST.
Information sent from a form via the POST method is invisible to others, since all names
and/or values are embedded within the body of the HTTP request. Also, there are no
limits on the amount of information to be sent.
Moreover, POST supports advanced functionality such as support for multi-part binary
input while uploading files to the server.
However, it is not possible to bookmark the page, as the submitted values are not visible.
GET
Information sent via a form using the GET method is visible to everyone (all variable
names and values are displayed in the URL). GET also sets limits on the amount of
information that can be sent - about 2000 characters.
However, because the variables are displayed in the URL, it is possible to bookmark the
page, which can be useful in some situations.
For example:
actionGet.php
Now, the form is submitted to the actionGet.php, and you can see the submitted data in
the URL:
Sessions
Using a session, you can store information in variables, to be used across multiple pages.
Information is not stored on the user's computer, as it is with cookies.
By default, session variables last until the user closes the browser.
Start a PHP Session
A session is started using the session_start() function.
Use the PHP global $_SESSION to set session variables.
Now, the color and name session variables are accessible on multiple pages, throughout the
entire session.
Session Variables
Another page can be created that can access the session variables we set in the previous
page:
Cookies
Cookies are often used to identify the user. A cookie is a small file that the server embeds
on the user's computer. Each time the same computer requests a page through a browser,
it will send the cookie, too. With PHP, you can both create and retrieve cookie values.
Create cookies using the setcookie() function:
name: Specifies the cookie's name
value: Specifies the cookie's value
expire: Specifies (in seconds) when the cookie is to expire. The value: time()+86400*30, will set
the cookie to expire in 30 days. If this parameter is omitted or set to 0, the cookie will expire at
the end of the session (when the browser closes). Default is 0.
path: Specifies the server path of the cookie. If set to "/", the cookie will be available within the
entire domain. If set to "/php/", the cookie will only be available within the php directory and all
sub-directories of php. The default value is the current directory in which the cookie is being set.
domain: Specifies the cookie's domain name. To make the cookie available on all subdomains of
example.com, set the domain to "example.com".
secure: Specifies whether or not the cookie should only be transmitted over a secure, HTTPS
connection. TRUE indicates that the cookie will only be set if a secure connection exists. Default
is FALSE.
httponly: If set to TRUE, the cookie will be accessible only through the HTTP protocol
(the cookiewill not be accessible to scripting languages). Using httponly helps reduce identity
theft using XSS attacks. Default is FALSE.
Cookies
The following example creates a cookie named "user" with the value "John".
The cookie will expire after 30 days, which is written as 86,400 * 30, in which 86,400
seconds = one day. The '/' means that the cookie is available throughout the entire
website.
We then retrieve the value of the cookie "user" (using the global variable $_COOKIE).
We also use the isset() function to find out if the cookie is set:
Manipulating Files
PHP offers a number of functions to use when creating, reading, uploading, and editing
files.
The fopen() function creates or opens a file. If you use fopen() with a file that does not
exist, the file will be created, given that the file has been opened for writing (w) or
appending (a).
Use one of the following modes to open the file.
r: Opens file for read only.
w: Opens file for write only. Erases the contents of the file or creates a new file if it
doesn't exist.
a: Opens file for write only.
x: Creates new file for write only.
r+: Opens file for read/write.
w+: Opens file for read/write. Erases the contents of the file or creates a new file if it
doesn't exist.
a+: Opens file for read/write. Creates a new file if the file doesn't exist
x+: Creates new file for read/write.
The example below creates a new file, "file.txt", which will be created in the same
directory that houses the PHP code.
Write to File
When writing to a file, use the fwrite() function.
The first parameter of fwrite() is the file to write to; the second parameter is the string to
be written.
The example below writes a couple of names into a new file called "names.txt".
Notice that we wrote to the file "names.txt" twice, and then we used the fclose() function to close
the file.
fclose()
The fclose() function closes an open file and returns TRUE on success or FALSE on
failure.
fopenAppending to a File
If you want to append content to a file, you need to open the file in append mode.
For example:
Appending to a File
Let's create an example of a form that adds filled-in data to a file.
Now, each time a name is entered and submitted, it's added to the "names.txt" file, along with a
new line.
The isset() function determined whether the form had been submitted, as well as whether the text
contained a value.
Reading a File
The file() function reads the entire file into an array. Each element within
the array corresponds to a line in the file:
<?php
$myfile = fopen("names.txt", "w");
$txt = "John\n";
fwrite($myfile, $txt);
$txt = "David\n";
fwrite($myfile, $txt);
fclose($myfile);
$read = file('names.txt');
foreach ($read as $line) {
echo $line .", ";
?>
Result:
This prints all of the lines in the file, and separates them with commas.
Reading a File
At the end of the output in the previous example, we would have a comma, as we print it
after each element of the array.
The following code lets us avoid printing that final comma.
<?php
$myfile = fopen("names.txt", "w");
$txt = "John\n";
fwrite($myfile, $txt);
$txt = "David\n";
fwrite($myfile, $txt);
fclose($myfile);
$read = file('names.txt');
$count = count($read);
$i = 1;
foreach ($read as $line) {
echo $line;
if($i < $count) {
echo ', ';
$i++;
?>
Result:
The $count variable uses the count function to obtain the number of elements in the $read array.
Then, in the foreach loop, after each line prints, we determine whether the current line is less than
the total number of lines, and print a comma if it is.