- How to Create a RESTful API in PHP With SlimPHP 4 and MySQL
- Prerequisites
- Let’s create the API!
- Install the dependencies
- Provision the database
- Create and run the Slim application
- Check that the application works
- Create the database connection
- Create the routes for the HTTP requests
- Saved searches
- Use saved searches to filter your results more quickly
- License
- maurobonfietti/rest-api-slim-php
- Name already in use
- Sign In Required
- Launching GitHub Desktop
- Launching GitHub Desktop
- Launching Xcode
- Launching Visual Studio Code
- Latest commit
- Git stats
- Files
- README.md
How to Create a RESTful API in PHP With SlimPHP 4 and MySQL
For those times when all you need is a simple solution that enables you to write quick, yet powerful applications, Slim is a great contender amongst the myriad of available PHP frameworks.
At its core, Slim is a microframework designed to receive HTTP requests, route the requests to the relevant controllers, and return the corresponding HTTP responses.
Slim’s minimalist environment makes it ideal for the development of both microservices and APIs that consume, repurpose, or publish data.
In this tutorial, you’re going to learn how to create a RESTful API using Slim 4, PHP, and MySQL.
Prerequisites
To complete this tutorial you will need the following:
Let’s create the API!
To begin, you need to create the project’s root directory, named customers-api. You can do this in your editor/IDE or by running the following commands on a mac.
mkdir customers-api cd customers-api
Now, let’s create two more directories named src and public inside the project’s root directory. src will contain another directory, named Models, and inside of that, there will be a file named Db.php. Then public will have an index.php file, which will contain the application’s middleware and routes for the API. To achieve all of this, run the following command in the terminal in the project’s root directory.
mkdir -p public src/Models && touch src/Models/Db.php public/index.php
Install the dependencies
Having created the project directory structure and switched to it, we now need to install the required dependencies. To do this, run the following command in the project’s root directory.
composer require --with-all-dependencies \ slim/slim:"4.*" \ slim/psr7 \ selective/basepath
Provision the database
Next, using your preferred database tool (such as MySQL’s command-line tool or the database tool in PhpStorm) run the SQL below to provision the database schema with the required tables, and two dummy records containing name, email, and phone fields for each person.
To begin, create a new database named customers_api by running the command below.
CREATE DATABASE customers_api;
Now, use the MySQL command below to confirm that the database has been created.
You’ll need to create a table inside the customers_api database and to do this, type the command below into the terminal.
Once inside the customers_api database, create a table named customers, with the following code.
CREATE TABLE customers ( id INT unsigned NOT NULL AUTO_INCREMENT, name VARCHAR(150) NOT NULL, email VARCHAR(150) NOT NULL, phone VARCHAR(150) NOT NULL, PRIMARY KEY(id) );
This creates a table with four columns, the customer’s id (which auto-increments), name, email and phone. Let’s test it has worked by typing the following SQL command in the terminal.
You should have the following result.
So, let’s add some sample records to the customers’ table. Copy and paste the following code into the terminal.
INSERT INTO customers ( name, email, phone) VALUES ( 'jane', 'jane_doe@mail.com', '123456789' ), ( 'john', 'john_doe@mail.com', '234567890' );
Now test the records have been added by typing out the following commands in the terminal.
You should have an output similar to the one below.
Create and run the Slim application
To accomplish this, copy the code below and paste it into public/index.php.
addRoutingMiddleware(); $app->add(new BasePathMiddleware($app)); $app->addErrorMiddleware(true, true, true); $app->get('/', function (Request $request, Response $response) < $response->getBody()->write('Hello World!'); return $response; >); $app->run();
In a Slim application, each route invokes a callback function that returns an HTTP response object. The code above begins by bringing in all the PSR-7 components that the app needs. It then instantiates the app and attaches three middleware classes to it.
The Slim middleware architecture is derived from the PSR-15 middleware interface. This is a series of concentric layers that encircle the core application, such that the last middleware added will be the first to be executed.
This concentric architecture means that when the Slim application is started, the request object passes through a series of middleware classes, or layers, working from the outside inward. The request enters the outermost middleware, then moves on to the next outermost middleware, continuing until it reaches the application.
For this reason, to catch any errors in the application, you call $app->addErrorMiddleware(true, true, true) last, otherwise any errors thrown from the other middlewares will not be caught.
Once the request object reaches the Slim application, the relevant route is dispatched, resulting in a response object exiting the concentric layers from the inside out. When the object passes the outermost middleware, it is turned into a raw HTTP response and then returned to the client.
Check that the application works
To check that the application works, first start it running, using PHP’s built-in web server, on port 8888, by running the command below.
php -S localhost:8888 -t public
Then, open your browser and enter http://localhost:8888/ into the URL panel. You should have a similar output to the screenshot below.
Create the database connection
To do this, you’ll first need to add a PSR-4 autoloader, by copying and pasting the following code into composer.json.
Now, regenerate Composer’s autoloader, by running the command below from the project’s top-level directory.
Next, you need to navigate to the src/Models/db.php file and paste the following code into it. Then, you need to update the values for $host , $user , $pass , and $dbname to match those in your database.
host;dbname=$this->dbname"; $conn = new PDO($conn_str, $this->user, $this->pass); $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); return $conn; > >
Create the routes for the HTTP requests
To do this, open public/index.php and include the use statements listed below.
Next, you need to create a route to fetch all the data from the database. To do that, copy and paste the code below towards the end of public/index.php, after the get request, but before the $app->run();
$app->get('/customers-data/all', function (Request $request, Response $response) < $sql = "SELECT * FROM customers"; try < $db = new Db(); $conn = $db->connect(); $stmt = $conn->query($sql); $customers = $stmt->fetchAll(PDO::FETCH_OBJ); $db = null; $response->getBody()->write(json_encode($customers)); return $response ->withHeader('content-type', 'application/json') ->withStatus(200); > catch (PDOException $e) < $error = array( "message" =>$e->getMessage() ); $response->getBody()->write(json_encode($error)); return $response ->withHeader('content-type', 'application/json') ->withStatus(500); > >);
Here we begin by telling the application to perform a get request on /customers-data/all, this will then invoke a call back routine that returns a PSR-7 response object.
To test the application, first, make sure MySQL is running and then use PHP’s built-in webserver, by copying and pasting the following command in the terminal.
php -S localhost:8888 -t public
With the application running, open http://localhost:8888/customers-data/all in your browser, where you should see a similar output to the one in the image below.
Now we need to create a route for a POST request. However, Slim’s implementation of PSR-7 does not support the sending of data in a JSON format, instead, they provide a BodyParsingMiddleware that handles this task. To do this, add the code below to public/index.php, placing it just after the call to AppFactory::create(); .
$app->addBodyParsingMiddleware();
Now, let’s create the POST request, by copying and pasting the following code into public/index.php.
post('/customers-data/add', function (Request $request, Response $response, array $args) < $data = $request->getParsedBody(); $name = $data["name"]; $email = $data["email"]; $phone = $data["phone"]; $sql = "INSERT INTO customers (name, email, phone) VALUES (:name, :email, :phone)"; try < $db = new Db(); $conn = $db->connect(); $stmt = $conn->prepare($sql); $stmt->bindParam(':name', $name); $stmt->bindParam(':email', $email); $stmt->bindParam(':phone', $phone); $result = $stmt->execute(); $db = null; $response->getBody()->write(json_encode($result)); return $response ->withHeader('content-type', 'application/json') ->withStatus(200); > catch (PDOException $e) < $error = array( "message" =>$e->getMessage() ); $response->getBody()->write(json_encode($error)); return $response ->withHeader('content-type', 'application/json') ->withStatus(500); > >);
Now, in Postman, create a new POST request, then:
And under the Body tab:
- Set the encoding-type to «raw»
- Set the Content-Type to JSON
- Paste the JSON below into the request’s body field.
Have a look at the screenshot below if you’re not sure what to do.
With the request configured, click Send to make the request. To confirm that a new entry has been created, head back to your browser and refresh it. You should see output similar to the example below.
Next, we’ll amend the customer whom we just added, by adding her last name. To do that, copy and paste the following route into public/index.php.
$app->put( '/customers-data/update/', function (Request $request, Response $response, array $args) < $id = $request->getAttribute('id'); $data = $request->getParsedBody(); $name = $data["name"]; $email = $data["email"]; $phone = $data["phone"]; $sql = "UPDATE customers SET name = :name, email = :email, phone = :phone WHERE try < $db = new Db(); $conn = $db->connect(); $stmt = $conn->prepare($sql); $stmt->bindParam(':name', $name); $stmt->bindParam(':email', $email); $stmt->bindParam(':phone', $phone); $result = $stmt->execute(); $db = null; echo "Update successful! "; $response->getBody()->write(json_encode($result)); return $response ->withHeader('content-type', 'application/json') ->withStatus(200); > catch (PDOException $e) < $error = array( "message" =>$e->getMessage() ); $response->getBody()->write(json_encode($error)); return $response ->withHeader('content-type', 'application/json') ->withStatus(500); > >);
To test it, create a PUT request with the following details:
Saved searches
Use saved searches to filter your results more quickly
You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session. You switched accounts on another tab or window. Reload to refresh your session.
Example of REST API with Slim PHP micro Framework.
License
maurobonfietti/rest-api-slim-php
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Name already in use
A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Sign In Required
Please sign in to use Codespaces.
Launching GitHub Desktop
If nothing happens, download GitHub Desktop and try again.
Launching GitHub Desktop
If nothing happens, download GitHub Desktop and try again.
Launching Xcode
If nothing happens, download Xcode and try again.
Launching Visual Studio Code
Your codespace will open once ready.
There was a problem preparing your codespace, please try again.
Latest commit
Git stats
Files
Failed to load latest commit information.
README.md
This is an example of a RESTful API built using the Slim PHP micro framework.
The API allows you to manage resources such as users, tasks, and notes.
The main technologies used in this project are:
- PHP 8
- Slim 3
- MySQL
- Redis
- dotenv
- PHPUnit
- JSON Web Tokens (JWT)
Also, I use other aditional tools like:
- Docker & Docker Compose
- Travis CI
- Swagger
- Code Climate
- Scrutinizer
- Sonar Cloud
- PHPStan
- PHP Insights
- Heroku
- CORS
- Git.
- Composer.
- PHP >= 8.0
- MySQL/MariaDB.
- Redis (Optional).
- or Docker.
You can create a new project running the following commands:
$ composer create-project maurobonfietti/rest-api-slim-php [my-api-name] $ cd [my-api-name] $ composer restart-db $ composer test $ composer start
In your terminal execute this commands:
$ git clone https://github.com/maurobonfietti/rest-api-slim-php.git && cd rest-api-slim-php $ cp .env.example .env $ composer install $ composer restart-db $ composer test $ composer start
You can use this project using docker and docker-compose.
Minimal Docker Version:
# Start the API (this is my alias for: docker-compose up -d --build). $ make up # To create the database and import test data from scratch. $ make db # Checkout the API. $ curl http://localhost:8081 # Stop and remove containers (it's like: docker-compose down). $ make down
If you get stuck, you can try this guide step by step.
Watch this mini-series of videos about Slim PHP (Spanish Audio 🔉 🇪🇸 🇦🇷 ).