PHP comes into its own when processing form information. Users enter information into specific fields in an online form. This data can be loaded into a database on the server, retrieved, updated and deleted at will, by using the powerful form handling techniques offered by PHP.
An HTML form is created with the form tag:
There are two methods available for sending form information to the handling page (nominated in the action attribute):
post is used when an action is carried out upon submission of the form. This might be sending an email, updating a database, or an on-page update using AJAX.
get is used to change the URL. Searches are nearly always conducted using
get (look at the URL next time you search for something in Google or Googlemaps). It adds one or more name-value pairs to the URL: e.g.
The raison d'être of forms is the facility of editing the form's fields. These can be any number of text boxes, radio buttons, select menus (dropdowns), and check boxes. These are placed between the opening and closing form tags. Forms can also contain upload fields (e.g. member account photos) for files of various types.
PHP can store the data inserted into a form element in special variables. A form defines an input as follows: e.g.
The information entered into the input field will be passed to the PHP handling form via a variable called $_REQUEST['customer_name']. The variable name is case sensitive.
Magic quotes are a now redundant feature of earlier versions of PHP. It inserts backslashes (\) into submitted form data before single and double quote marks. This was to prevent unintended clashes in the use of quote marks intended as an integral part of a string rather than functional characters. However, to avoid these backslashes appearing in the text when it is printed out, they can be removed using:
When a form is submitted, it needs to be validated (checked for completed mandatory fields, and correctness of input type). The data is then submitted to a PHP in a multi-dimensional array called
\$_POST, if the method is specified as
To have a single page both display and handle a form, create a hidden form input. This will not be displayed, so cannot be altered by the user, but submits an element to the POST array containing the value '1' (i.e. true) for the element called 'submitted':
If the form has been submitted,
\$_POST['submitted'] contains the value '1', so the form data is processed. If the form has not been submitted the
else clause will be executed - and the form will be displayed instead, waiting for submission. To have the form submit and the page display the form again, leave out the
A sticky form is one that remembers the data in input fields, and selections made from drop-downs and radio buttons, after submission. This is useful to avoid the inconvenience of the user needing to re-enter all the data because the form failed a validation test on one field.
value attribute in a form's input tag presets a default value:
PHP can preset the value by printing it:
Text areas can be preset:
Radio buttons and checkboxes can be preset:
Pull-down menus can be preset:
After data has been input and a form submitted, the data can be echoed in the form again quite simply:
Double quotes around HTML attributes, such as the
value attribute in a form input, ensures that strings with white space are stored fully.
Uploading files requires two directories: a temporary and a final directory.
It is a good first step to run a
phpinfo() function to check PHP has been set up correctly to permit uploads, and that a temporary
tmp file exists with write permissions.
These can be edited in the
php.ini file on a local server.
uploads folder and place it in the root of the domain. Make sure this folder has full permissions for anyone to read/write.
The upload system has two parts: the HTML form and the PHP script which handles the submitted form and file.
The above code results in this form element:
When submitted the uploaded file is available within the
\$_FILES superglobal array variable, containing the array elements:
file_upload.php will contain instructions as to what to do with the uploaded file. This is to move it from the temporary folder to a destination folder, and to name it something sensible:
\$allowed array restricts the allowed file types to the MIME (Multipurpose Internet Mail Extensions) types specified. This is for security, to ensure that executable files are not loaded.
Content © Renewable-Media.com. All rights reserved. Created : August 12, 2014 Last updated :October 14, 2015
The most recent article is:
View this item in the topic:
and many more articles in the subject:
Philosophy is just a way of talking about discoveries that have already been made.
Website © renewable-media.com | Designed by: Andrew Bone