webroot/vendor/symfony/routing
2024-12-01 20:57:32 +01:00
..
Annotation 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
Attribute 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
DependencyInjection 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
Exception 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
Generator 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
Loader 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
Matcher 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
Requirement 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
Alias.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
CHANGELOG.md 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
CompiledRoute.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
composer.json 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
LICENSE 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
README.md 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
RequestContext.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
RequestContextAwareInterface.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
Route.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
RouteCollection.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
RouteCompiler.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
RouteCompilerInterface.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
Router.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00
RouterInterface.php 2024.12.01 20:57:28 2024-12-01 20:57:32 +01:00

Routing Component

The Routing component maps an HTTP request to a set of configuration variables.

Getting Started

$ composer require symfony/routing
use App\Controller\BlogController;
use Symfony\Component\Routing\Generator\UrlGenerator;
use Symfony\Component\Routing\Matcher\UrlMatcher;
use Symfony\Component\Routing\RequestContext;
use Symfony\Component\Routing\Route;
use Symfony\Component\Routing\RouteCollection;

$route = new Route('/blog/{slug}', ['_controller' => BlogController::class]);
$routes = new RouteCollection();
$routes->add('blog_show', $route);

$context = new RequestContext();

// Routing can match routes with incoming requests
$matcher = new UrlMatcher($routes, $context);
$parameters = $matcher->match('/blog/lorem-ipsum');
// $parameters = [
//     '_controller' => 'App\Controller\BlogController',
//     'slug' => 'lorem-ipsum',
//     '_route' => 'blog_show'
// ]

// Routing can also generate URLs for a given route
$generator = new UrlGenerator($routes, $context);
$url = $generator->generate('blog_show', [
    'slug' => 'my-blog-post',
]);
// $url = '/blog/my-blog-post'

Sponsor

The Routing component for Symfony 6.4 is backed by redirection.io.

redirection.io logs all your websites HTTP traffic, and lets you fix errors with redirect rules in seconds. Give your marketing, SEO and IT teams the right tool to manage your website traffic efficiently!

Help Symfony by sponsoring its development!

Resources