Web scripting with PHP, MySQL & Apache
by Greg Chiponda published by AfroSP (African Open Source Project) www.afrosp.com
TOC -Table of Contents Chapter 1 : PHP Basics Chapter 2 : Variable Scope Chapter 3 : Data Types Chapter 4 : Operators & constants Chapter 5 : PHP String variables Chapter 6 : Conditional statements Chapter 7 : Loops Chapter 8 : Arrays Chapter 9 : Functions Chapter 10: Forms
Chapter 1 : PHP Basics What is PHP PHP is a open source server-side scripting language originally created by Rasmus Lerdorf in 1995 as "Personal Home Page" but now the recursive acronym "PHP: Hypertext Preprocessor" is used to describe PHP current functionality. Alternative server-side scripting languages to PHP include ASP, Java Servlets, Perl & Python. What is PHP used for PHP was designed to develop dynamic websites, but it can also be used for: Server-side scripting (website development) Command line scripting using cron (on Linux) or Task Scheduler (on Windows) Writing desktop applications with a graphical user interface using PHP-GTK Types of files you can create with PHP With PHP you can generate any type as output including : HTML, PDF , Flash movies (using libswf and Ming) Text, such as XHTML and any other XML file What you need to make PHP work To make PHP work you need the PHP parser (CGI or server module), a web server and a web browser. The PHP parser was re-written by Zeev Suraski and Andi Gutmans and re-named the Zend Engine. PHP can work with many database systems and servers.. How does PHP work PHP code is embedded in files HTML files with the file extension .php. When a you request a web page written in PHP, the web browser send the request to the serve which then sends the PHP file to a PHP parser which then delivers the web document to the web browser for you to see. Installing PHP You can install PHP manually or by using a pre-configured package like XAMP Apache configuration file is called httpd.conf PHP configuration file is php.ini PHP Syntax A PHP script always starts with <?php and ends with ?> or shorthand <? and end with ?>. A PHP file must have a .php extension. The semicolon is used in PHP to tell one set of instructions from another, so each code line in PHP must end with a semicolon. A statement represents an instruction to the PHP engine and usualy ends with a semicolon. Exceptions to this include statements that enclose other statements and statements that end a block of code. <?php statement; ?> Outputing text in PHP There are two basic statements to output text with PHP: echo and print. Language constructs. 1. print () print () is a language construct that behaves like a function and is used to outputs data. It accepts a collection of characters (strings), which can be enclosed in single or double quotation marks. It does not necessarily require parenthisis. 2. echo () echo () is a language construct similar to the print () statement, it outputs data except that it does not return a value. The famous Hello World" in PHP The 101 of learning any programming language is to know how to output Hello World <html> <body> <?php
echo "Hello World"; ?> </body> </html> Comments in PHP A comment is text in a script that is ignored by the PHP engine. Comments can be used to make code more readable or to annotate a script.PHP uses two forward slashes (//) or a single hash sign (#) to make a one-line comment and /*Comment*/ to make a multi-line comment. PHP Variables Variables are containers for storing information, that enable you to create templates for operations (adding two numbers, for example) without worrying about what values the variables contain. Rules used for naming PHP variables are: Variables in PHP starts with a $ sign, followed by the name of the variable The variable name must begin with a letter or the underscore character A variable name can only contain alpha-numeric characters & underscores (A-z, 0-9, and _ ) A variable name should not contain spaces Variable names are case sensitive (y and Y are two different variables) Creating PHP Variables A variable is created the moment you first assign a value to it: i.e $firstname =Greg . After the execution of the statement above, the variable firstname will hold the value Greg.To create an empty varible you assign NULL to the variable i.e $firstname =NULL . String variable vs Numerical variable To create a text variable you need to put quotes around the value, whilst when creating a numerical variable you do not need to put any quotes. <?php $txt="Hello World!"; $x=16; ?> PEAR (PHP Extension and Application Repository) PEAR provides a growing collection of libraries and scripts for extending PHP's functionality PHP is a Loosely Typed Language In PHP, a variable does not need to be declared before adding a value to it. PHP automatically converts the variable to the correct data type, depending on its value.In a strongly typed programming language, you have to declare (define) the type and name of the variable before using it.
Chapter 2: Variable Scope PHP Variable Scope The scope of a variable is the portion of the script in which the variable can be referenced.PHP has four different variable scopes: local scope, global scope, static scope and parameter scope. Chapter 2 will deal in more detail with variable scope, data types, Local Scope A variable declared within a PHP function is local and can only be accessed within that function. (the variable has local scope). The script above will not produce any output because the echo statement refers to the local scope variable $a, which has not been assigned a value within this scope.Local variables are deleted as soon as the function is completed. <?php $a = 5; // global scope function myTest() {echo $a; // local scope} myTest(); ?> Global Scope Global scope refers to any variable that is defined outside of any function. Global variables can be accessed from any part of the script that is not inside a function.To access a global variable from within a function, use the global keyword: PHP also stores all global variables in an array called $GLOBALS[index]. <?php $a = 5; $b = 10; function myTest() {global $a, $b; $b = $a + $b;} myTest(); echo $b; ?> <?php $a = 5; $b = 10; function myTest() {$GLOBALS['b'] = $GLOBALS['a'] + $GLOBALS['b'];} myTest(); echo $b; ?>
Static Scope When a function is completed, all of its variables are normally deleted. However, sometimes you want a local variable to not be deleted.To do this, use the static keyword when you first declare the variable: static $rememberMe; Then, each time the function is called, that variable will still have the information it contained from the last time the function was called. The variable is still local to the function. Parameters A parameter or argument is a local variable whose value is passed to the function by the calling code. Parameters are declared in a parameter list as part of the function declaration: function myTest($para1,$para2,...) {// function code}
Chapter 3 : Data types Data types PHP is loosely typed, which means it calculates data types as data is assigned to each variable. PHP has six (6) data types Type Integer Double String Boolean Object Array Resource NULL A database $firstname=NULL Reference to a third-party resource (a database, for example) An uninitialized variable Example 5 1.743 AfroSP false Description A whole number A floating-point number A collection of characters True or False
1. gettype () : used to acquire the type of any variable, you place a variable between the paretheses of the function call gettype () returns a string representing the relevant type. i.e echo gettype($variable_name); 2. var_dump () : used to tel you a variables type and its contents 3. is_array (), is_bool(, is_double(, is_int(), is_object(), is_string(, is_null(), is_resource() : used to test for a specific variable type 4. settype () : used to change the type of a variable i.e settype ($variable type); Changing Type There are three ways to change the type of a variable 1. Casting By placing the name of a data type in parentheses in front of a variable, you create a copy of that variable's value converted to the data type specified.The principle difference between settype() and a cast is the fact that casting produces a copy, leaving the original variable untouched.
2. Settype 3. Using functions PHP provides functions to convert values into integers, doubles, and strings. These functions accept values of any type apart from array or object and return a converted value doubleval () intval () strval () Double quotes and strings Double quotation marks on strings cause value substitution and parsing for escape characters. Escape characters lose special meaning when preceded by a backslash (\) character i.e \n for a newline character \t for a tab, \" to print a double-quoted character within a double-quoted string \\ to print a backslash \$ to print a dollar sign Single quotes and strings If you want a string to be output exactly as you typed it, you can use single quotation marks.
Chapter 4 : Operators & Constants An operator is a symbol or series of symbols that, when used in conjunction with values, performs an action and usually produces a new value.An operand is a value used in conjunction with an operator. There are usually two operands to one operator.Whilst an expression is any combination of functions, values, and operators that resolves to a value. As a rule of thumb, if you can use it as if it were a value, it is an expression. i.e in the expression 3 + 7 we have 3 and 7 as the operands and (+) as the operator More operators 1. Assignment operator (=) 2. Arithmetic operators : (+), (-), (/), (*), (%) 3. Concatenation operator (.) : it appends the right operand to the left so i.e "hello"." world" = hello world 4. Comparison operators equivalence(==), non-equivalence(!=), identical(===), greater than(>), greater than or equal to(=>), less than(<), less than or equal to(=<) 5. Combined assignment operators (+=), (-=), (/=), (*=), (%=) and (.=) 6. Logical operators (|| or), (Xor), (&& And) and (! Not) Constants The value of a constatnt does not change throughout the execution of the script. A constant is defined using PHP's built-in function define() . define() optionally accepts a third boolean argument that determines whether the constant name should be case insensitive. By default, constants are case sensitive, but by passing true to the define() function you can change this behavior. i.e define ("CONSTANT_NAME", 42); Predefined Constants PHP automatically provides some built-in constants, which are useful for generating error messages 1. ___FILE___, for example, returns the name of the file currently being read by the PHP engine 2. ___LINE___ returns the line number of the file. 3. PHP_VERSION. This can be useful if you want to limit a script to run on a particular PHP release.
The assignment operator = is used to assign values to variables in PHP. The arithmetic operator + is used to add values together.
Incrementing/Decrementing Operators
Operator ++ x x ++ -- x x -Name Pre-increment Post-increment Pre-decrement Post-decrement Description Increments x by one, then returns x Returns x, then increments x by one Decrements x by one, then returns x Returns x, then decrements x by one
Logical Operators
Operator x and y Name And Description Example x=6 True if both x and y are true y=3 (x < 10 and y > 1) returns true x=6 True if either or both x and y are true y=3 (x==6 or y==5) returns true x=6 True if either x or y is true, but not y=3 both (x==6 xor y==3) returns false x=6 True if both x and y are true y=3 (x < 10 && y > 1) returns true x=6 True if either or both x and y are true y=3 (x==5 || y==5) returns false x=6 True if x is not true y=3 !(x==y) returns true
x or y
Or
x xor y
Xor
x && y
And
x || y
Or
!x
Not
Array Operators
Operator x+y x == y x === y x != y x <> y x !== y Name Union Equality Identity Inequality Inequality Non-identity Description Union of x and y True if x and y have the same key/value pairs True if x and y have the same key/value pairs in the same order and of the same types True if x is not equal to y True if x is not equal to y True if x is not identical to y
Chapter 5 : PHP String variables A string variable is used to store and manipulate text. Below, the PHP script assigns the text "Hello World" to a string variable called $txt: <?php $txt="Hello World"; echo $txt; ?> The output of the code above will be: Hello World The Concatenation Operator The concatenation operator (.) is the only string operator in PHP. It is used to put two string values together. <?php $txt1="Hello World!"; $txt2="What a nice day!"; echo $txt1 . " " . $txt2; ?> The output of the code above will be: Hello World! What a nice day! We use a space character to separate the two strings. The strlen() function The strlen() function is used to return the length of a string. <?php echo strlen("Hello world!"); ?> The output of the code above will be:12 The strpos() function The strpos() function is used to search for a character/text within a string. If a match is found, this function will return the character position of the first match. If no match is found, it will return FALSE. <?php echo strpos("Hello world!","world"); ?> The output of the code above will be: 6 since the position of the string "world" in the example above is 6. The reason that it is 6 (and not 7), is that the first character position in the string is 0, and not 1.
Chapter 6 : Conditional statements PHP has a wide range of functions used to control flow mainly conditional statements and loops. This chapter will look at conditional statements. Conditional statements are used to perform different actions based on different conditions. if statement if...else statement if...elseif....else statement switch statement if statement Use the if statement to execute some code only if a specified condition is true. Syntax : if (condition) code to be executed if condition is true; <?php $d=date("D"); if ($d=="Fri") echo "Have a nice weekend!"; ?> if...else statement Use the if....else statement to execute some code if a condition is true and another code if a condition is false. Syntax if (condition) {code to be executed if condition is true;} else {code to be executed if condition is false;} The following example will output "Have a nice weekend!" if the current day is Friday, otherwise it will output "Have a nice day!": <?php $d=date("D"); if ($d=="Fri") {echo "Have a nice weekend!";} else {echo "Have a nice day!";} ?> if...elseif....else statement Use the if....elseif...else statement to select one of several blocks of code to be executed. Syntax if (condition) {code to be executed if condition is true;} elseif (condition) {code to be executed if condition is true;} else {code to be executed if condition is false;}
The following example will output "Have a nice weekend!" if the current day is Friday, and "Have a nice Sunday!" if the current day is Sunday. Otherwise it will output "Have a nice day!": <?php $d=date("D"); if ($d=="Fri") {echo "Have a nice weekend!";} elseif ($d=="Sun") {echo "Have a nice Sunday!";} else {echo "Have a nice day!";} ?> switch statement Use the switch statement to select one of many blocks of code to be executed. Syntax switch (n) { case label1: code to be executed if n=label1; break; case label2: code to be executed if n=label2; break; default: code to be executed if n is different from both label1 and label2; } This is how it works: First we have a single expression n (most often a variable), that is evaluated once. The value of the expression is then compared with the values for each case in the structure. If there is a match, the block of code associated with that case is executed. Use break to prevent the code from running into the next case automatically. The default statement is used if no match is found. <?php $x=1; switch ($x) { case 1: echo "Number 1"; break; case 2: echo "Number 2"; break; case 3: echo "Number 3"; break; default: echo "No number between 1 and 3"; } ?>
Chapter 7 : Loops Loops execute a block of code a specified number of times, or while a specified condition is true. while do...while for foreach while The while loop executes a block of code while a condition is true. Syntax while (condition) {code to be executed;} The example below defines a loop that starts with i=1. The loop will continue to run as long as i is less than, or equal to 5. i will increase by 1 each time the loop runs: <?php $i=1; while($i<=5) {echo "The number is " . $i . "<br />"; $i++;} ?> Output: The number is 1 The number is 2 The number is 3 The number is 4 The number is 5 do...while The do...while statement will always execute the block of code once, it will then check the condition, and repeat the loop while the condition is true. Syntax do {code to be executed;} while (condition); The example below defines a loop that starts with i=1. It will then increment i with 1, and write some output. Then the condition is checked, and the loop will continue to run as long as i is less than, or equal to 5: <?php $i=1; do {$i++; echo "The number is " . $i . "<br />";} while ($i<=5); ?> Output: The number is 2 The number is 3 The number is 4 The number is 5 The number is 6
foreach The for loop is used when you know in advance how many times the script should run. for (init; condition; increment) {code to be executed; } Parameters: init: Mostly used to set a counter (but can be any code to be executed once at the beginning of the loop) condition: Evaluated for each loop iteration. If it evaluates to TRUE, the loop continues. If it evaluates to FALSE, the loop ends. increment: Mostly used to increment a counter (but can be any code to be executed at the end of the iteration) The init and increment parameters above can be empty or have multiple expressions (separated by commas). <?php for ($i=1; $i<=5; $i++) {echo "The number is " . $i . "<br />"; } ?> Output: The number is 1 The number is 2 The number is 3 The number is 4 The number is 5 The foreach Loop The foreach loop is used to loop through arrays. Syntax foreach ($array as $value) {code to be executed;} For every loop iteration, the value of the current array element is assigned to $value (and the array pointer is moved by one) - so on the next loop iteration, you'll be looking at the next array value. <?php $x=array("one","two","three"); foreach ($x as $value) {echo $value . "<br />";} ?> Output: one two three
Chapter 8 : Arrays An array stores multiple values in one single variable.A variable is a storage area holding a number or text. The problem is, a variable will hold only one value.An array is a special variable, which can store multiple values in one single variable. If you have a list of items (a list of car names, for example), storing the cars in single variables could look like this: $cars1="Saab"; $cars2="Volvo"; $cars3="BMW"; However, what if you want to loop through the cars and find a specific one? And what if you had not 3 cars, but 300? The best solution here is to use an array! An array can hold all your variable values under a single name. And you can access the values by referring to the array name. Each element in the array has its own index so that it can be easily accessed. In PHP, there are three kind of arrays: Numeric array - An array with a numeric index Associative array - An array where each ID key is associated with a value Multidimensional array - An array containing one or more arrays Numeric Arrays A numeric array stores each array element with a numeric index. There are two methods to create a numeric array. 1. In the following example the index are automatically assigned (the index starts at 0): $cars=array("Saab","Volvo","BMW","Toyota"); 2. In the following example we assign the index manually: $cars[0]="Saab"; $cars[1]="Volvo"; $cars[2]="BMW"; $cars[3]="Toyota"; In the following example you access the variable values by referring to the array name and index: <?php $cars[0]="Saab"; $cars[1]="Volvo"; $cars[2]="BMW"; $cars[3]="Toyota"; echo $cars[0] . " and " . $cars[1] . " are Swedish cars."; ?> The code above will output: Saab and Volvo are Swedish cars. Associative Arrays An associative array, each ID key is associated with a value.When storing data about specific named values, a numerical array is not always the best way to do it.With associative arrays we can use the values as keys and assign values to them. In this example we use an array to assign ages to the different persons: $ages = array("Peter"=>32, "Quagmire"=>30, "Joe"=>34); This example is the same as example 1, but shows a different way of creating the array: $ages['Peter'] = "32"; $ages['Quagmire'] = "30"; $ages['Joe'] = "34"; The ID keys can be used in a script: <?php
$ages['Peter'] = "32"; $ages['Quagmire'] = "30"; $ages['Joe'] = "34"; echo "Peter is " . $ages['Peter'] . " years old."; ?> The code above will output: Peter is 32 years old. Multidimensional Arrays In a multidimensional array, each element in the main array can also be an array. And each element in the subarray can be an array, and so on. In this example we create a multidimensional array, with automatically assigned ID keys: $families = array ( "Griffin"=>array ("Peter", "Lois","Megan"), "Quagmire"=>array ("Glenn"), "Brown"=>array ("Cleveland","Loretta", "Junior") ); The array above would look like this if written to the output: Array([Griffin] => Array ([0] => Peter [1] => Lois [2] => Megan ) [Quagmire] => Array ([0] => Glenn) [Brown] => Array ([0] => Cleveland [1] => Loretta [2] => Junior ) ) Lets try displaying a single value from the array above: echo "Is " . $families['Griffin'][2] . " a part of the Griffin family?"; The code above will output: Is Megan a part of the Griffin family?
Chapter 9: Functions The real power of PHP comes from its functions. In PHP, there are more than 700 built-in functions. Create a PHP Function A function will be executed by a call to the function. Syntax : function functionName(){code to be executed;} PHP function guidelines: Give the function a name that reflects what the function does The function name can start with a letter or underscore (not a number) A simple function that writes my name when it is called: <?php function writeName() {echo "Kai Jim Refsnes";} echo "My name is "; writeName(); ?> Output: My name is Kai Jim Refsnes PHP Functions - Adding parameters To add more functionality to a function, we can add parameters. A parameter is just like a variable. Parameters are specified after the function name, inside the parentheses. The following example will write different first names, but equal last name: <?php function writeName($fname) { echo $fname . " Refsnes.<br />"; } echo "My name is "; writeName("Kai Jim"); echo "My sister's name is "; writeName("Hege"); echo "My brother's name is "; writeName("Stale"); ?> Output: My name is Kai Jim Refsnes. My sister's name is Hege Refsnes. My brother's name is Stale Refsnes. The following function has two parameters: <?php function writeName($fname,$punctuation) {echo $fname . " Refsnes" . $punctuation . "<br />";} echo "My name is "; writeName("Kai Jim","."); echo "My sister's name is "; writeName("Hege","!"); echo "My brother's name is ";
writeName("Stle","?"); ?> Output: My name is Kai Jim Refsnes. My sister's name is Hege Refsnes! My brother's name is Stle Refsnes? PHP Functions - Return values To let a function return a value, use the return statement. <?php function add($x,$y) { $total=$x+$y; return $total; } echo "1 + 16 = " . add(1,16); ?> Output: 1 + 16 = 17
Chapter 10 : Forms The PHP $_GET and $_POST variables are used to retrieve information from forms, like user input. The most important thing to notice when dealing with HTML forms and PHP is that any form element in an HTML page will automatically be available to your PHP scripts. The example below contains an HTML form with two input fields and a submit button: <form action="welcome.php" method="post"> Name: <input type="text" name="fname" /> Age: <input type="text" name="age" /> <input type="submit" /> </form> When a user fills out the form above and clicks on the submit button, the form data is sent to a PHP file, called "welcome.php": "welcome.php" looks like this: Welcome <?php echo $_POST["fname"]; ?>!<br /> You are <?php echo $_POST["age"]; ?> years old. Output could be something like this: Welcome John! You are 28 years old. The PHP $_GET and $_POST variables will be explained in the next chapters. Form Validation User input should be validated on the browser whenever possible (by client scripts). Browser validation is faster and reduces the server load. You should consider server validation if the user input will be inserted into a database. A good way to validate a form on the server is to post the form to itself, instead of jumping to a different page. The user will then get the error messages on the same page as the form. This makes it easier to discover the error. In PHP, the predefined $_GET variable is used to collect values in a form with method="get". The $_GET Variable The predefined $_GET variable is used to collect values in a form with method="get" Information sent from a form with the GET method is visible to everyone (it will be displayed in the browser's address bar) and has limits on the amount of information to send. <form action="welcome.php" method="get"> Name: <input type="text" name="fname" /> Age: <input type="text" name="age" /> <input type="submit" /> </form> When the user clicks the "Submit" button, the URL sent to the server could look something like this: http://www.w3schools.com/welcome.php?fname=Peter&age=37 The "welcome.php" file can now use the $_GET variable to collect form data (the names of the form fields will automatically be the keys in the $_GET array): Welcome <?php echo $_GET["fname"]; ?>.<br /> You are <?php echo $_GET["age"]; ?> years old! When to use method="get"? When using method="get" in HTML forms, all variable names and values are displayed in the URL. Note: This method should not be used when sending passwords or other sensitive information! However, because the variables are displayed in the URL, it is possible to bookmark the page. This can be useful in some cases. The get method is not suitable for very large variable values. It should not be used with values exceeding 2000 characters. In PHP, the predefined $_POST variable is used to collect values in a form with method="post".
The $_POST Variable The predefined $_POST variable is used to collect values from a form sent with method="post". Information sent from a form with the POST method is invisible to others and has no limits on the amount of information to send.However, there is an 8 Mb max size for the POST method, by default (can be changed by setting the post_max_size in the php.ini file). <form action="welcome.php" method="post"> Name: <input type="text" name="fname" /> Age: <input type="text" name="age" /> <input type="submit" /> </form> When the user clicks the "Submit" button, the URL will look like this:http://www.w3schools.com/welcome.php The "welcome.php" file can now use the $_POST variable to collect form data (the names of the form fields will automatically be the keys in the $_POST array): Welcome <?php echo $_POST["fname"]; ?>!<br /> You are <?php echo $_POST["age"]; ?> years old. When to use method="post"? Information sent from a form with the POST method is invisible to others and has no limits on the amount of information to send. However, because the variables are not displayed in the URL, it is not possible to bookmark the page. The PHP $_REQUEST Variable The predefined $_REQUEST variable contains the contents of both $_GET, $_POST, and $_COOKIE. The $_REQUEST variable can be used to collect form data sent with both the GET and POST methods. Welcome <?php echo $_REQUEST["fname"]; ?>!<br /> You are <?php echo $_REQUEST["age"]; ?> years old.