clock  Mon - Sun 8.00 AM - 8.00 PM
fb
instagram
play store
pinterest

How to Create REST API in Laravel

writter  Sumit Dey Sarkar
Date  27 May 2023
Language  Laravel
How to Create REST API in Laravel

How to Create REST API in Laravel

In this tutorial we will learn how create rest api in Laravel.

 

How to Create REST API in Laravel

 

 

Create REST API in Laravel

When working with mobile applications, the Laravel  Rest API is used. With Laravel, creating APIs is simple. Laravel offers a simple method for producing Rest APIs.

 

Step 1 - Set up Laravel

Make sure Laravel is installed on your computer first. Use below command to create a new laravel file:

composer create-project --prefer-dist laravel/laravel your-api-project

 

Step 2 - Create a route

Open the routes/api.php file and define your API routes. For example:

Route::get('/users', 'UserController@index');
Route::get('/users/{id}', 'UserController@show');
Route::post('/users', 'UserController@store');
Route::put('/users/{id}', 'UserController@update');
Route::delete('/users/{id}', 'UserController@destroy');

 

Step 3 - Create a controller

Next, create a controller to handle the API requests. To create a UserController, run the command below:

php artisan make:controller UserController

Above command will create a UserController file in the app/Http/Controllers directory. Open the file and add the necessary methods to handle the API requests:

<?php

namespace App\Http\Controllers;

use App\Models\User;
use Illuminate\Http\Request;

class UserController extends Controller
{
    public function index()
    {
        $users = User::all();
        return response()->json($users);
    }

    public function show($id)
    {
        $user = User::findOrFail($id);
        return response()->json($user);
    }

    public function store(Request $request)
    {
        // Validate the request data
        $validatedData = $request->validate([
            'name' => 'required',
            'email' => 'required|email|unique:users',
            // Add more validation rules as needed
        ]);

        // Create a new user
        $user = User::create($validatedData);

        return response()->json($user, 201);
    }

    public function update(Request $request, $id)
    {
        // Find the user
        $user = User::findOrFail($id);

        // Validate the request data
        $validatedData = $request->validate([
            'name' => 'required',
            'email' => 'required|email|unique:users,email,'.$user->id,
            // Add more validation rules as needed
        ]);

        // Update the user
        $user->update($validatedData);

        return response()->json($user);
    }

    public function destroy($id)
    {
        // Find the user
        $user = User::findOrFail($id);

        // Delete the user
        $user->delete();

        return response()->json(null, 204);
    }
}

 

Step 4 - Run the API

Finally, you can run your Laravel development server to test the API:

php artisan serve

 

Now you have a basic RESTful API in Laravel! You can send requests to the defined endpoints using tools like Postman or cURL to interact with the API.

 

Note - This is a simple example to get you started. You can customize and extend it based on your specific requirements.

Comments 0

Leave a comment

Coursera, Codeacademy, Udacity, W3Schools, Udemy, Alison, TheNewBoston, edX, P.S.Codewars,Freecodecamp, Managing technical debt blog, Scrimba, Codepen, Codepen/challenges, The Odin Project, htmlreference.​io, cssreference.​io, Frontend Mentor, Dev Challenges, MDN, Code Mentor, Coding Dojo, CSS Battle, Codier, Ace Frontend, Can I Use, CSS Tricks, 30 Seconds of Code,tutorialspoint, Neumorphism, Shaddows Brumm, Fancy Border Radius, Glow Generator, Clothoid Corners, Glassmorphism, Clipy, CSS Filters, Base64 Image, Quantity Queries, Animations, Cubic-Bezier, Keyframes, Wait Animate, Transition.Style, graphic design, web design, website design, website builder, web developer, web designer, webdesign, ecommerce website, web design company, website creator, website designer, responsive web design, web development company, best website design, web design software, web page design, build a website, web developer salary, design website, web design courses, how to design a website, web design inspiration, website layout, web designer salary, web application development, ecommerce website design, web agency, software development company, web design tutorial, web programming, design company, website design templates, what is web designing, web developer jobs, website developer, web design agency, freelance web developer, web design services, freelance web designer, graphic design websites, web solutions, ecommerce website development, free website design, web development courses, webdev, web developers, web development tools, website design services, developpeur web, web design london, website design ideas, web designing and programming, design a website, web design and development, web dev, web development services, homepage design, best designed websites, cheap website design, learn web design, web design templates, web design tools, web design jobs, website design inspiration, web design india, flash website, website developers, designer websites, website services, website design cost, good website design, site design, simple website design, cool website designs, modern website design, graphic designer websites, webcode, best web design software, website making, free web design software, mobile website design, learn web development, front end web developer, how to become a web developer, web developer portfolio, web development company in india, python web development, web development tutorial, website company, website design and development, web company, webdesigning, professional website design, affordable web design, best web design company, creative web design, top website designs, website design pricing, web developer tools, how to develop a website