Close Menu
    DevStackTipsDevStackTips
    • Home
    • News & Updates
      1. Tech & Work
      2. View All

      Sunshine And March Vibes (2025 Wallpapers Edition)

      May 11, 2025

      The Case For Minimal WordPress Setups: A Contrarian View On Theme Frameworks

      May 11, 2025

      How To Fix Largest Contentful Paint Issues With Subpart Analysis

      May 11, 2025

      How To Prevent WordPress SQL Injection Attacks

      May 11, 2025

      I never thought I’d love a triangular PC gaming headset, but these RGB-lit wireless cans are pretty great

      May 11, 2025

      When is the best time to book your flight? Google just gave us the golden answer

      May 11, 2025

      Diablo 4 gives you the chance to win a Mother’s Day candle and express your love (or hatred) with “Mother’s Judgement”

      May 10, 2025

      Here’s how to speedrun the Call of Duty: Black Ops 6 and Warzone Blaze of Glory event as fast as possible

      May 10, 2025
    • Development
      1. Algorithms & Data Structures
      2. Artificial Intelligence
      3. Back-End Development
      4. Databases
      5. Front-End Development
      6. Libraries & Frameworks
      7. Machine Learning
      8. Security
      9. Software Engineering
      10. Tools & IDEs
      11. Web Design
      12. Web Development
      13. Web Security
      14. Programming Languages
        • PHP
        • JavaScript
      Featured

      Build Digital Assets & Earn Through Referrals with Biela — A Genuine Opportunity for Entrepreneurs

      May 11, 2025
      Recent

      Build Digital Assets & Earn Through Referrals with Biela — A Genuine Opportunity for Entrepreneurs

      May 11, 2025

      Laravel Routing

      May 10, 2025

      Big Node, VS Code, and Mantine updates

      May 9, 2025
    • Operating Systems
      1. Windows
      2. Linux
      3. macOS
      Featured

      I never thought I’d love a triangular PC gaming headset, but these RGB-lit wireless cans are pretty great

      May 11, 2025
      Recent

      I never thought I’d love a triangular PC gaming headset, but these RGB-lit wireless cans are pretty great

      May 11, 2025

      Drakboot is a GRUB graphical configuration tool

      May 11, 2025

      Le notizie minori del mondo GNU/Linux e dintorni della settimana nr 19/2025

      May 11, 2025
    • Learning Resources
      • Books
      • Cheatsheets
      • Tutorials & Guides
    Home»Development»Laravel Routing

    Laravel Routing

    May 10, 2025

    Routes are your Laravel Application’s entry point, defining how it responds to different URLS and HTTP requests.

    A route is a way to specify the URL patterns your application should respond to what action to take when a specific URL is accessed. Routes are defined in the routes folder, particularly in web.php (Web routes) and api.php (API routes). Each route has a URL path and an associated callback function or controller method that handles the request.

    Basic Routing

    1. Open the routes/web.php file.
    2. Define a route using Route::get to specify that this route should respond to GET Requests.

    Example: Basic route that returns text.

    Route::get('/hello', function(){
         return "Welcome, to PythonCodeVerse"
    });

    Explanation:

    Route::get: This specifies that this route only responds to GET Requests.

    '/hello': This is the URL path. When you visit HTTP://localhost:800/hello, this route will be triggered.

    Callback function: The anonymous function (function () {……}) returns ‘Welcome, to PythonCodeVerse’ to user.

    To see the output, start your Laravel server with:

    php artisan serve

    Open your browser and go to http://localhost:8000/hello. You should see “Welcome, to PythonCodeVerse” displayed on the screen.

    HTTP Requests: GET, POST, PUT, DELETE

    HTTP requests allow clients (Like browsers) to communicate with the server, each with its specific purpose:

    GET: Retrieves data from the server, typically used for displaying pages.

    POST: Sends data to the server, commonly used for submitting forms

    PUT: Update existing data on the server.

    DELETE: Removes data from the server.

    Defining GET and POST Routes

    In Laravel, you can define routes for different HTTP request types by replacing Route::get with Route:post, Route:put, or Route::delete.

    Example: POST Route

    Route::post('/submit', function(){
    return 'Form Submitted'
    })

    In this example, the /submit route will respond to POST requests. As shown below, you would typically use a form to make this request.

    <form action="/submit" method="POST">
    @csrf
    <button type="submit">Submit</button>
    </form>

    Here, we set method=”POST” to make a POST request to the /submit route.

    Notice the @csrf directive, which adds a CSRF (Cross-Site Request Forgery) token for security. Laravel requires this token for all POST, PUT, and DELETE requests to prevent unauthorised access.

    PUT and DELETE Routes

    To handle updates and deletions, we use PUT and DELETE requests, which are often used in RESTful applications.

    //PUT
    Route::put('/update', function (){
    return 'Data updated!';
    }
    );
    
    //DELTE
    Route::put('/delete', function (){
    return 'Data deleted!';
    }
    );

    Just like post, you would typically make PUT and DELETE requests via form or JavaScript, setting the method accordingly. Laravel makes it easy to specify within a form by using hidden fields.

    Example: PUT request with a form

    <form action="/update" method="POST">
    @csrf
    @method('PUT')
    <button type="submit">Update</button>
    </form>

    In the above example, we use @method('PUT') to indicate that this form should be treated as a PUT request. This tells Laravel to match the form submission to the /update route defined with Route::put

    Dynamic Routes with Route Parameters

    Laravel allows you to create dynamic routes by using parameters in the URL. This is particularly useful for situations where you want to pass specific information, like user id or product id, product name, through the URL.

    Example: Defining a route with a parameter

    Route::get('/user/{id}', function($id){
       return "User id: $id"
    });

    In this example:

    • {id} is a route parameter. Laravel will capture this value from the URL and pass it to the callback function as the $id variable.
    • When you access http://localhost:8000/user/1, Laravel will display “User id:1” because the $id parameter is set to 1.

    Multiple Parameters

    Example: A route with two parameters

    Route::get('/user/{id}/post/{postid}', function($id, $postid){
       return "User id: $id, Post ID: $postid";
    });

    This route will respond to URLS like http://loclahost:8000/user/1/post/5, displaying “User id:1 Post id:5”.

    Optional Parameters

    Sometimes, you may want to make a route parameter optional. To do this, add a ? after the parameter name and provide a default value in the callback function.

    Example: Defining a route with an optional parameter

    Route::get('/user/{name?}', functon
    ($name='Guest'){
    return "Hello, $name!";
    });

    In this example, if you visit http://localhost:8000/user/john, it displays “Hello, john!” if you omit the name

    Ex: http://localhost:8000/user , It displays “Hello, Guest!”

    Named Routes

    Named routes allow you to assign a name to a route, making it easy to reference in your application. This is particularly useful when generating URLS or redirecting to specific routes.

    Example: Defining a named route

    Route::get('/dashboard', function(){
      return view('dashboard');
    })->name('dashboard');

    You can then reference this route by its name elsewhere in your application, like in links or redirects.

    Example: Generating a URL to a named route.

    $url = route('dashboard'); // Generates URL for /dashboard

    Grouping Routes

    Laravel lets you group routes, which is useful for organising routes that share a common feature, like middleware or prefixes.

    Example: Grouping routes with a prefix.

    Route::prefix('admin')->group(function(){
          Route::get('/dashboard', function(){
          return 'Admin Dashboard'
         });
          Route::get('/setting', function(){
          return 'Admin setting'
         });
    });

    With this setup, you can access the routes at http://localhost:8000/admin/dashboard and http://localhost:8000/admin/settings. The prefix method automatically prepends “admin” to each route in the group.

    Route Middleware

    Middleware allows you to filter requests by applying a login before the requests reach their intended destination route. Common use cases include authentication and access control.

    Example: Protecting a route with authentication middleware.

    Route::get('/profile', function (){
     return view('profile');
    })->middleware('auth');

    In this example, the auth middleware ensures that only authenticated users can access the /profile route.

    The post Laravel Routing appeared first on PHPGurukul.

    Source: Read More 

    Hostinger
    Facebook Twitter Reddit Email Copy Link
    Previous ArticleCannot Delete Emails from Deleted Items Folder in Office 365 Mailbox
    Next Article LWiAI Podcast #208 – Claude Integrations, ChatGPT Sycophancy, Leaderboard Cheats

    Related Posts

    Security

    Nmap 7.96 Launches with Lightning-Fast DNS and 612 Scripts

    May 11, 2025
    Common Vulnerabilities and Exposures (CVEs)

    CVE-2025-4540 – MTSoftware C-Lodop Unquoted Search Path Vulnerability

    May 11, 2025
    Leave A Reply Cancel Reply

    Continue Reading

    Evaluating RAG applications with Amazon Bedrock knowledge base evaluation

    Machine Learning

    Paragraphs

    Development

    North Korean APT Kimsuky Uses forceCopy Malware to Steal Browser-Stored Credentials

    Development

    Want a free Samsung Music Frame? Buy one of these TVs or soundbars to get one

    News & Updates

    Highlights

    Development

    How do you enter data from a jhtml Area element using selenium?

    November 13, 2024

    Now in the application that i have to automate, there’s a jhtml Area element. This is a sample jhtml area: http://pietschsoft.com/demo/jhtmlarea/.

    So the jhtml area has two elements for the text you enter. I have tried entering text using the text area tag. But doesn’t work out. Any ideas?

    This AI tool studied medical journals to answer your health queries

    January 8, 2025

    I put DeepSeek AI’s coding skills to the test – here’s where it fell apart

    January 28, 2025

    ERROR_ASSERTION_FAILURE 668 (0x29C) [Solved]

    February 11, 2025
    © DevStackTips 2025. All rights reserved.
    • Contact
    • Privacy Policy

    Type above and press Enter to search. Press Esc to cancel.