Table of Contents
How Routing Works
Project Setup
How to Redirect All HTTP Requests to the Router
Redirect Using Apache
Redirect Using NGINX
How to Create the Routing System
Add Dummy Data in the Views Files
Final thoughts
Home Backend Development PHP Tutorial How to Build a Routing System for a PHP App from Scratch

How to Build a Routing System for a PHP App from Scratch

Nov 29, 2024 pm 04:23 PM
php

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.

截屏2024-11-29 16.11.16.png

How Routing Works

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:

  • Defines which action to run for each incoming request.
  • Generates SEO-friendly URLs (e.g. /views/users instead of views/user.php?all).

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.

Project Setup

Before moving forward, let’s see what the project will look like:

How to Build a Routing System for a PHP App from ScratchFile structure

Use the shell commands below to initiate the project:

mkdir php-routing & cd php-routingtouch index.php .htaccess
Copy after login
Copy after login
Copy after login
  • .htaccess: A directory-level Apache configuration file. You don’t need it if you use an NGINX server.
  • index.php: This is the router and entry file of the project. All incoming requests will be redirected here.
  • views: This folder holds all the UIs for the project.

How to Redirect All HTTP Requests to the Router

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.

Redirect Using Apache

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
Copy after login
Copy after login
Copy after login
  • line 1: We activate the Apache server’s runtime rewriting engine.
  • line 2: We limit access to physical files.
  • line 3: We redirect all the upcoming requests to the index.php.

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
Copy after login
Copy after login

In the code above, replace /folder/ with the name of the folder containing your site.

Redirect Using NGINX

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]
Copy after login
Copy after login

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.

How to Create the Routing System

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}
Copy after login
Copy after login

This variable will help us to compare with many routes (paths) and call the appropriate view interface.

$request = $_SERVER['REQUEST_URI'];
Copy after login
Copy after login

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
Copy after login
Copy after login
Copy after login

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:

  • Both '' and '/' are used to match site.com as well as site.com/ for when users are in the root of the app or website.
  • There's a special case statement, default, to match anything that wasn't matched by the other cases, i.e. when the route is unknown.

Let's now add some dummy data in our views.

Add Dummy Data in the Views Files

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
Copy after login
Copy after login
RewriteEngine On
RewriteBase /folder/
RewriteRule ^index\.php$ - [L]RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /folder/index.php [L]
Copy after login
Copy after login
location / {
        try_files $uri $uri/ /index.php}
Copy after login
Copy after login
$request = $_SERVER['REQUEST_URI'];
Copy after login
Copy after login

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.

Final thoughts

In this tutorial, you learned how to create a basic routing system from scratch, including:

  • How to create a file named index.php at the root of the project. This is the router for your app.
  • How to redirect all incoming requests to the router. You do this in the configuration file of your server.
  • How to create the routing system with a switch statement in the router.

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!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Have Crossplay?
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

How To Set Up Visual Studio Code (VS Code) for PHP Development How To Set Up Visual Studio Code (VS Code) for PHP Development Dec 20, 2024 am 11:31 AM

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

7 PHP Functions I Regret I Didn't Know Before 7 PHP Functions I Regret I Didn't Know Before Nov 13, 2024 am 09:42 AM

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

How do you parse and process HTML/XML in PHP? How do you parse and process HTML/XML in PHP? Feb 07, 2025 am 11:57 AM

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Apr 05, 2025 am 12:04 AM

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

PHP Program to Count Vowels in a String PHP Program to Count Vowels in a String Feb 07, 2025 pm 12:12 PM

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Explain late static binding in PHP (static::). Explain late static binding in PHP (static::). Apr 03, 2025 am 12:04 AM

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

What are PHP magic methods (__construct, __destruct, __call, __get, __set, etc.) and provide use cases? What are PHP magic methods (__construct, __destruct, __call, __get, __set, etc.) and provide use cases? Apr 03, 2025 am 12:03 AM

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.

See all articles