-
-
Notifications
You must be signed in to change notification settings - Fork 6
Routing
The interaction between the browser and the application occurs via URLs.
When a user visits a website or makes an HTTP request to a specific URL, the routing
system directs that request to the appropriate code or action.
In essence, routing is the process of associating URLs with specific actions,
allowing the execution of particular logic and the return of a response.
This mapping is done within the config/routes.php
file. The following is an example
for the login page action.
// Define which action should be invoked when the URL is /login
$app->get('/login', LoginPageAction::class);
// The `->get` function corresponds to the HTTP method used to access the URL.
The following functions are available for different HTTP methods:
-
->get
to retrieve data -
->post
to create or submit data -
->put
to update data -
->delete
to delete data -
->patch
to partially update data -
->options
to get information about the communication options available on the request/response chain -
->any
to match any HTTP method -
->map
to match multiple HTTP methods -
->redirect
to redirect to another URL
In the login example, there are two separate actions associated with the same URL but different HTTP methods.
- Display login page (GET-Request)
- Submit login form (POST-Request)
File: config/routes.php
use Slim\App;
use App\Application\Action\Authentication\Page\LoginPageAction;
use App\Application\Action\Authentication\Ajax\LoginSubmitAction;
return function (App $app) {
// Define route that should display the login page and give it a name
$app->get('/login', LoginPageAction::class)->setName('login-page');
// Submit login form
$app->post('/login', LoginSubmitAction::class)->setName('login-submit');
}
URLs can also have variable parts. For example, if we want to define a route to read
specific clients based on their id, a named placeholder can be used for the id
.
$app->get('/clients/{id}', ClientReadPageAction::class);
The label id
can later be accessed via the $args
array that is passed into the Action as
the third parameter
of the __invoke
method.
The format of the placeholder can be specified as follows {label:regexPattern}
. For example:
- Alphanumeric variable:
{label}
- Numeric variable:
{label:[0-9]+}
- String variable:
{label:[a-zA-Z]+}
URLs that share the same prefix can be grouped together.
For instance, all URLs that start with /client
can be grouped together.
$app->group('/clients', function (RouteCollectorProxy $group) {
$group->get('/{client_id:[0-9]+}', ClientReadPageAction::class)->setName('client-read-page');
$group->get('', ClientFetchListAction::class)->setName('client-list');
$group->post('', ClientCreateAction::class)->setName('client-create-submit');
$group->put('/{client_id:[0-9]+}', ClientUpdateAction::class)->setName('client-update-submit');
$group->delete('/{client_id:[0-9]+}', ClientDeleteAction::class)->setName('client-delete-submit');
});
More on routes in the Slim 4 documentation.
Slim app basics
- Composer
- Web Server config and Bootstrapping
- Dependency Injection
- Configuration
- Routing
- Middleware
- Architecture
- Single Responsibility Principle
- Action
- Domain
- Repository and Query Builder
Features
- Logging
- Validation
- Session and Flash
- Authentication
- Authorization
- Translations
- Mailing
- Console commands
- Database migrations
- Error handling
- Security
- API endpoint
- GitHub Actions
- Scrutinizer
- Coding standards fixer
- PHPStan static code analysis
Testing
Frontend
Other