Route Groups

Route Groups

Route Groups is an essential feature in Laravel, which allows you to group all the routes. Routes Groups are beneficial when you want to apply the attributes to all the routes. If you use route groups, you do not have to apply the attributes individually to each route; this avoids duplication. It allows you to share the attributes such as middleware or namespaces, without defining these attributes on each individual route. These shared attributes can be passed in an array format as the first parameter to the Route::group method.

Syntax of Route Group

 
  1. Route::group( [ ] , callback);  

Parameters

[ ]: It is an array passed to the group method as a first parameter.

Example of Route Groups

web.php

 
  1. Route::group([], function()  
  2. {  
  3.    Route::get('/first',function()  
  4.  {  
  5.    echo "first route";  
  6.  });  
  7. Route::get('/second',function()  
  8.  {  
  9.    echo "second route";  
  10.  });  
  11. Route::get('/third',function()  
  12.  {  
  13.    echo "third route";  
  14.  });  
  15. });  

In the above code, we define the group() method, which contains the two parameters, i.e., array and closure. Inside the closure, we can define the routes as many as we want. In the above code, we define three routes.

Output:

When we access the URL "localhost/laravelproject/public/first", then the output would be:

Laravel Route Groups

When we access the URL "localhost/laravelproject/public/second", then the output would be:

Laravel Route Groups

When we access the URL "localhost/laravelproject/public/third", then the output would be:

Laravel Route Groups

Path Prefixes

Path prefixes are used when we want to provide a common URL structure.

We can specify the prefix for all the routes defined within the group by using the prefix array option in the route group.

Let's understand through an example.

web.php

  1. Route::group(['prefix' => 'tutorial'], function()  
  2. {  
  3.    Route::get('/aws',function()  
  4.  {  
  5.    echo "aws tutorial";  
  6.  });  
  7. Route::get('/jira',function()  
  8.  {  
  9.    echo "jira tutorial";  
  10.  });  
  11. Route::get('/testng',function()  
  12.  {  
  13.    echo "testng tutorial";  
  14.  });  
  15. });  

The above code contains three routes which can be accessed by the following URLs:

/tutorial/aws

Laravel Route Groups

/tutorial/jira

Laravel Route Groups

/tutorial/testng

Laravel Route Groups

Middleware

We can also assign middleware to all the routes within a group. Middleware can be defined before creating the group by using the middleware method.

Let's understand through an example.

web.php

  1. Route::middleware(['age'])->group( function()  
  2. {  
  3.   
  4.    Route::get('/aws',function()  
  5.  {  
  6.    echo "aws tutorial";  
  7.  });  
  8. Route::get('/jira',function()  
  9.  {  
  10.    echo "jira tutorial";  
  11.  });  
  12. Route::get('/testng',function()  
  13.  {  
  14.    echo "testng tutorial";  
  15.  });  
  16.   
  17. });  

CheckAge.php (middleware)

  1. <?php  
  2. namespace App\Http\Middleware;  
  3. use Closure;  
  4. class CheckAge  
  5.   
  6. {  
  7. /** 
  8.      * Handle an incoming request. 
  9.      * 
  10.       
  11. * @param 
  12.   \Illuminate\Http\Request  $request 
  13.      
  14.  * @param  \Closure  $next 
  15.      * @return mixed 
  16.      */  
  17.    
  18.    public function handle($request, Closure $next)  
  19.       
  20. {  
  21.         
  22. //return "middleware";  
  23. echo "Hello javaTpoint <br>";  
  24. return $next($request);  
  25.       
  26. }  
  27. }  

Output:

Laravel Route Groups
Laravel Route Groups
Laravel Route Groups

Route Name Prefixes

The name method is used to prefix each route name with some specified string. In the name method, we need to specify the string with a trailing character in the prefix.

Let's see an example.

web.php

 
  1. Route::name('admin.')->group(function()  
  2. {  
  3.    Route::get('users', function()  
  4. {  
  5.  return "admin.users";  
  6. })->name('users');  
  7. });