If you’re just at the beginning of your journey in PHP development, chances are that you use complete file names in the URL to navigate your application, like server/contact.php. No worries, we all started that way, and it’s how we learn.
Today, I want to help you improve how you navigate files in your application. We’ll be talking about routing, as it’s crucial in any modern application. It'll help you take a step forward in your professional PHP development.
A routing system simply maps an HTTP request to a request handler (function or method). In other words, it defines how we navigate or access different parts of an app without the need to type the file name. You can do this by creating or setting routes (or paths). For example, the route server/contact lets us access the contact.php file.
First thing first, let me recall you what a routing is. Routing allows us to structure our app in a better way and get rid of messy URLs. These are two main features offered by any good routing system:
To do a routing system, we need a router, which is no more than the entry file to our app. By default, this entry file is named as index.php. Inside the file, we define the routing system thanks to [switch](https://www.php.net/manual/en/control-structures.switch.php) or [match](https://www.php.net/manual/en/control-structures.match.php) statements.
Last but not least, we must redirect all requests to the router. This is done in the configuration file of the PHP server.
Before moving forward, let’s see what the project will look like:
File structure
Use the shell commands below to initiate the project:
mkdir php-routing & cd php-routingtouch index.php .htaccess
We've said earlier that the redirection is done in the PHP server config file. So you'll need to make some tweaks depending on whether you use an Apache or NGINX server.
Here, we can easily use the .htaccess file that we have already created in the root of the project. Add the directives below:
mkdir php-routing & cd php-routingtouch index.php .htaccess
Note: If the site or app is note at the root of the server (or if we don’t have a virtual host), here's what the .htaccess should look like:
RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^(.*)$ index.php
In the code above, replace /folder/ with the name of the folder containing your site.
The default configuration file is name nginx.conf. This file can be found in etc/nginx, usr/local/nginx/conf, or /usr/local/etc/nginx.
To redirect to index.php use the command below:
RewriteEngine On RewriteBase /folder/ RewriteRule ^index\.php$ - [L]RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule . /folder/index.php [L]
The location / block specifies that this is a match for all locations unless explicitly specified location /
The try_files directive tells the server that for any request to the URI that matches the block in the location, try the $uri (or $uri/) first, and if the file is present, serve the file. Otherwise, the fallback option (index.php) is used. And this last behavior is what we want.
Reload the server after the modification.
We now know how routing works, and we are even sending all requests to the router. Now is the time to write the code for the router in index.php.
First, create a variable to hold the HTTP request string:
location / { try_files $uri $uri/ /index.php}
This variable will help us to compare with many routes (paths) and call the appropriate view interface.
$request = $_SERVER['REQUEST_URI'];
What's happening here? The switch statement is similar to a series of if statements on the same expression (variable). It executes a code only when a case statement is found whose expression evaluates to a value that matches the value of the switch expression. Let me illustrate this so that you can get it well.
Let's consider that our variable holds the value /views/users/. When the piece of the code above will be run, PHP will check if the value /views/users equals to the value of case statement, which in our case is /views/users. So, this condition will evaluate to true, PHP will call the file /views/users.php. If the condition evaluates to false, PHP will check for the next case statement until the end of the switch block.
Note: Every time the case statement evaluates to true PHP will continue to execute the code in the following case statements without necessary evaluating those case statements. In our case, PHP also requires views/dep.php. To avoid this "bad behavior", you must add break statement after each case statement.
Let now put everything together into our index.php file:
mkdir php-routing & cd php-routingtouch index.php .htaccess
As you already know, we start off by storing a user request in the $request variable, then we use it in the switch statement. For the sake of clean code, I have created a variable to hold the view directory name.
You'll also notice two other things:
Let's now add some dummy data in our views.
We have already created all files in the views directory. Let's just move to this directory and add some content in each file.
Just put some content in each file:
RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^(.*)$ index.php
RewriteEngine On RewriteBase /folder/ RewriteRule ^index\.php$ - [L]RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule . /folder/index.php [L]
location / { try_files $uri $uri/ /index.php}
$request = $_SERVER['REQUEST_URI'];
As you can see, each file just contains a title and a paragraph. Feel free to add whatever content you like and test the router.
In this tutorial, you learned how to create a basic routing system from scratch, including:
The above is the detailed content of How to Build a Routing System for a PHP App from Scratch. For more information, please follow other related articles on the PHP Chinese website!