搜索
首页后端开发php教程使用Symfony路由组件在PHP应用程序中设置路由
使用Symfony路由组件在PHP应用程序中设置路由Sep 03, 2023 pm 10:37 PM
php应用程序symfony路由组件设置路由

使用Symfony路由组件在PHP应用程序中设置路由

什么是 Symfony 路由组件?

Symfony 路由组件是一个非常流行的路由组件,它由多个框架改编而成,如果您希望在 PHP 应用程序中设置路由,它可以提供很大的灵活性。

如果您已经构建了自定义 PHP 应用程序并正在寻找功能丰富的路由库,那么 Symfony 路由组件是最佳候选之一。它还允许您以 YAML 格式定义应用程序的路由。

从安装和配置开始,我们将通过实际示例来演示该组件用于路由配置的各种选项。在本文中,您将了解到:

  • Symfony 路由组件的安装和配置
  • 如何设置基本路线
  • 如何从 YAML 文件加载路由
  • 将路由创建为注释:推荐方式

安装和配置

在本节中,我们将安装在 PHP 应用程序中设置路由所需的库。我假设您已经在系统中安装了 Composer,因为我们需要它来安装 Packagist 上提供的必要库。

安装 Composer 后,请继续使用以下命令安装核心路由组件。

$composer require symfony/routing

虽然路由组件本身足以在您的应用程序中提供全面的路由功能,但我们还将继续安装一些其他组件,以使我们的生活更轻松并丰富现有的核心路由功能。

首先,我们将继续安装 HttpFoundation 组件,该组件为 PHP 全局变量和响应相关函数提供面向对象的包装器。它确保您不需要直接访问 $_GET$_POST 等全局变量。

$composer require symfony/http-foundation

接下来,如果您想在 YAML 文件而不是 PHP 代码中定义应用程序路由,则 YAML 组件可以发挥作用,因为它可以帮助您将 YAML 字符串转换为 PHP 数组,反之亦然。

$composer require symfony/yaml

最后,我们将安装 Config 组件,它提供了几个实用程序类来初始化和处理不同类型文件(如 YAML、INI、XML 等)中定义的配置值。在我们的例子中,我们将使用它从 YAML 文件加载路由。

$composer require symfony/config

这就是安装部分,但是你应该如何使用它呢?事实上,只需将 Composer 创建的 autoload.php 文件包含在您的应用程序中即可,如以下代码片段所示。

<?php
require_once './vendor/autoload.php';
 
// application code
?>

设置基本路由

在上一节中,我们完成了必要的路由组件的安装。现在,您可以立即在 PHP 应用程序中设置路由。

让我们继续创建包含以下内容的 basic_routes.php 文件。

<?php
require_once './vendor/autoload.php';
 
use Symfony\Component\Routing\Matcher\UrlMatcher;
use Symfony\Component\Routing\RequestContext;
use Symfony\Component\Routing\RouteCollection;
use Symfony\Component\Routing\Route;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Routing\Generator\UrlGenerator;
use Symfony\Component\Routing\Exception\ResourceNotFoundException;
 
try
{
    // Init basic route
    $foo_route = new Route(
      '/foo',
      array('controller' => 'FooController')
    );
 
    // Init route with dynamic placeholders
    $foo_placeholder_route = new Route(
      '/foo/{id}',
      array('controller' => 'FooController', 'method'=>'load'),
      array('id' => '[0-9]+')
    );
 
    // Add Route object(s) to RouteCollection object
    $routes = new RouteCollection();
    $routes->add('foo_route', $foo_route);
    $routes->add('foo_placeholder_route', $foo_placeholder_route);
 
    // Init RequestContext object
    $context = new RequestContext();
    $context->fromRequest(Request::createFromGlobals());
 
    // Init UrlMatcher object
    $matcher = new UrlMatcher($routes, $context);
 
    // Find the current route
    $parameters = $matcher->match($context->getPathInfo());
 
    // How to generate a SEO URL
    $generator = new UrlGenerator($routes, $context);
    $url = $generator->generate('foo_placeholder_route', array(
      'id' => 123,
    ));
 
    echo '<pre class="brush:php;toolbar:false">';
    print_r($parameters);
 
    echo 'Generated URL: ' . $url;
    exit;
}
catch (ResourceNotFoundException $e)
{
  echo $e->getMessage();
}

使用 Symfony Routing 组件设置路由通常要经历如下列出的一系列步骤。

  • 为每个应用程序路由初始化 Route 对象。
  • 将所有 Route 对象添加到 RouteCollection 对象添加到
  • 对象。
  • RequestContext初始化
  • 对象,该对象保存当前请求上下文信息。
  • RouteCollection 对象和 RequestContext 对象来初始化 UrlMatcher通过传递
  • 对象和
对象来初始化 UrlMatcher 对象。

初始化不同路由的路由对象foo

让我们继续定义一个非常基本的

路由。Route

$foo_route = new Route(
  '/foo',
  array('controller' => 'FooController')
);

构造函数的第一个参数是 URI 路径,第二个参数是匹配此特定路由时要返回的自定义属性数组。通常,它是控制器和方法的组合,当请求此路由时您要调用它们。

接下来我们看一下参数化路由。foo/1foo/123 等类似的 URI。请注意,我们将 {id} 参数限制为仅限数字值,因此它不会匹配 foo/bar 这样的 URI,因为 {id}

$foo_placeholder_route = new Route(
  '/foo/{id}',
  array('controller' => 'FooController', 'method'=>'load'),
  array('id' => '[0-9]+')
);

上述路由可以匹配

参数以字符串形式提供。

将所有路由对象添加到 RouteCollection 对象RouteCollection

下一步是将我们在上一节中初始化的路由对象添加到 🎜 对象。🎜
$routes = new RouteCollection();
$routes->add('foo_route', $foo_route);
$routes->add('foo_placeholder_route', $foo_placeholder_route);

正如您所看到的,这非常简单,您只需要使用 RouteCollection 对象的 add 方法来添加路由对象。 add 方法的第一个参数是路由名称,第二个参数是路由对象本身。

初始化 RequestContext 对象

接下来,我们需要初始化RequestContext对象,该对象保存当前请求上下文信息。当我们初始化 UrlMatcher 对象时,我们将需要这个对象,因为我们稍后会详细介绍它。

$context = new RequestContext();
$context->fromRequest(Request::createFromGlobals());

初始化 UrlMatcher 对象

最后,我们需要初始化 UrlMatcher 对象以及路由和上下文信息。

// Init UrlMatcher object
$matcher = new UrlMatcher($routes, $context);

现在,我们拥有了可以匹配路线的一切。

如何匹配路由

这是 UrlMatcher 对象的 match 方法,它允许您将任何路由与一组预定义路由进行匹配。

match 方法将 URI 作为其第一个参数,并尝试将其与预定义的路由进行匹配。如果找到该路由,它将返回与该路由关联的自定义属性。另一方面,如果没有与当前 URI 关联的路由,它会抛出 ResourceNotFoundException 异常。

$parameters = $matcher->match($context->getPathInfo());

在我们的例子中,我们通过从 $context 对象获取当前 URI 来提供它。因此,如果您访问 https://your-domain/basic_routes.php/foo URL,则 $context->getPathInfo() 返回 foo,并且我们已经为 foo URI 定义了一条路由,因此它应该返回以下内容。

Array
(
    [controller] => FooController
    [_route] => foo_route
)

现在,让我们继续访问 http://your-domain/basic_routes.php/foo/123 URL 来测试参数化路由。

Array
(
    [controller] => FooController
    [method] => load
    [id] => 123
    [_route] => foo_placeholder_route
)

如果您可以看到 id 参数与适当的值 123 绑定,则说明有效。

接下来,让我们尝试访问不存在的路由,例如 http://your-domain/basic_routes.php/unknown-route,您应该会看到以下消息。

No routes found for "/unknown-route".

这就是如何使用 match 方法查找路由。

除此之外,您还可以使用路由组件在应用程序中生成链接。提供了 RouteCollectionRequestContext 对象,UrlGenerator 允许您为特定路由构建链接。

$generator = new UrlGenerator($routes, $context);
$url = $generator->generate('foo_placeholder_route', array(
  'id' => 123,
));

generate 方法的第一个参数是路由名称,第二个参数是数组,如果是参数化路由,则可以包含参数。上面的代码应该生成 /basic_routes.php/foo/123 URL。

从 YAML 文件加载路由

在上一节中,我们使用 RouteRouteCollection 对象构建了自定义路由。事实上,路由组件提供了不同的方式供您选择来实例化路由。您可以从各种加载器中进行选择,例如 YamlFileLoaderXmlFileLoaderPhpFileLoader

在本节中,我们将通过 YamlFileLoader 加载器来了解如何从 YAML 文件加载路由。

路由 YAML 文件

继续创建包含以下内容的 routes.yaml 文件。

foo_route:
    path:     /foo
    controller: App\Controller\FooController::index
    methods:    GET
 
foo_placeholder_route:
    path:     /foo/{id}
    controller: App\Controller\FooController::load
    methods:    GET
    requirements:
        id: '[0-9]+'

示例文件

接下来,继续使用以下内容创建 load_routes_from_yaml.php 文件。

load('routes.yaml');
 
    // Init RequestContext object
    $context = new RequestContext();
    $context->fromRequest(Request::createFromGlobals());
 
    // Init UrlMatcher object
    $matcher = new UrlMatcher($routes, $context);
 
    // Find the current route
    $parameters = $matcher->match($context->getPathInfo());
 
    // How to generate a SEO URL
    $generator = new UrlGenerator($routes, $context);
    $url = $generator->generate('foo_placeholder_route', array(
      'id' => 123,
    ));
 
    echo '
';
    print_r($parameters);
 
    echo 'Generated URL: ' . $url;
    exit;
}
catch (ResourceNotFoundException $e)
{
  echo $e->getMessage();
}

在这种情况下唯一不同的是我们初始化路由的方式!

$fileLocator = new FileLocator(array(__DIR__));
$loader = new YamlFileLoader($fileLocator);
$routes = $loader->load('routes.yaml');

我们使用 YamlFileLoader 加载器从 routes.yaml 文件加载路由,而不是直接在 PHP 本身中对其进行初始化。除此之外,一切都是相同的,并且应该产生与 basic_routes.php 文件相同的结果。

一体化路由器

在本节中,我们将介绍 Router 类,它允许您使用更少的代码行快速设置路由。

继续制作包含以下内容的 all_in_one_router.php 文件。

<?php
require_once './vendor/autoload.php';
 
use Symfony\Component\Routing\RequestContext;
use Symfony\Component\Routing\Router;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Routing\Generator\UrlGenerator;
use Symfony\Component\Config\FileLocator;
use Symfony\Component\Routing\Loader\YamlFileLoader;
use Symfony\Component\Routing\Exception\ResourceNotFoundException;
 
try
{
    $fileLocator = new FileLocator(array(__DIR__));
 
    $requestContext = new RequestContext();
    $requestContext->fromRequest(Request::createFromGlobals());
 
    $router = new Router(
        new YamlFileLoader($fileLocator),
        'routes.yaml',
        array('cache_dir' => __DIR__.'/cache'),
        $requestContext
    );
 
    // Find the current route
    $parameters = $router->match($requestContext->getPathInfo());
 
    // How to generate a SEO URL
    $routes = $router->getRouteCollection();
    $generator = new UrlGenerator($routes, $requestContext);
    $url = $generator->generate('foo_placeholder_route', array(
      'id' => 123,
    ));
 
    echo '<pre class="brush:php;toolbar:false">';
    print_r($parameters);
 
    echo 'Generated URL: ' . $url;
    exit;
}
catch (ResourceNotFoundException $e)
{
  echo $e->getMessage();
}

一切都几乎相同,除了我们实例化了 Router 对象以及必要的依赖项。

$router = new Router(
    new YamlFileLoader($fileLocator),
    'routes.yaml',
    array('cache_dir' => __DIR__.'/cache'),
    $requestContext
);

完成后,您可以立即使用 Router 对象的 match 方法进行路由映射。

$parameters = $router->match($requestContext->getPathInfo());

此外,您还需要使用 Router 对象的 getRouteCollection 方法来获取路由。

$routes = $router->getRouteCollection();

将路由创建为注释:推荐方式

在本节中,我们将讨论如何实现基于注释的路由。它正在成为在不同框架之间定义路由的最流行的方法之一。

在我们继续实现基于注释的路由之前,我们需要安装几个软件包。让我们快速完成此操作,如以下代码片段所示。

$composer require symfony/framework-bundle
$composer require doctrine/annotations
$composer require doctrine/cache

如您所见,我们安装了三个不同的组件。

在您的 composer.json 文件中,添加以下内容:

"autoload": {
    "psr-4": {
        "App\\": "app/"
    }
}

现在,运行以下命令。

$composer dump-autoload

现在,我们准备好文件了。

继续创建包含以下内容的 index.php 文件。

load(__DIR__ . '/src/Controller/');
$context = new RequestContext();
$context->fromRequest(Request::createFromGlobals());

$matcher = new UrlMatcher($routes, $context);
$parameters = $matcher->match($context->getPathInfo());

$controllerInfo = explode('::',$parameters['_controller']);

$controller = new $controllerInfo[0];
$action = $controllerInfo[1];

$controller->$action();

现在,让我们在 src/Controller/FooController.php 中创建包含以下内容的控制器文件。

<?php
namespace App\Controller;

use Symfony\Component\Routing\Annotation\Route;

class DefaultController
{
    /**
     * @Route("/",name="index")
     */
    public function index()
    {
        echo "Index action";
    }

    /**
     * @Route("/hello",name="hello")
     */
    public function hello()
    {
        echo "Hello action";
    }
}

您可能已经注意到,我们以注释的形式为每个方法定义了路由。这种方法的好处是,它允许您在与这些路由关联的控制器的代码旁边定义路由。

继续访问 https://your-domain/index.php/ URL。根据以下路由配置,它应该调用 index 方法。

/**
 * @Route("/",name="index")
 */

另一方面,如果您尝试访问 http://your-domain/index.php/hello URL,它应该调用 DefaultController 控制器的 hello 方法类。

这就是基于注释的路由的工作原理!

结论

继续探索路由组件中可用的其他选项。

今天,我们探索了 Symfony 路由组件,它使得在 PHP 应用程序中实现路由变得轻而易举。在此过程中,我们创建了一些示例来演示路由组件的各个方面。

以上是使用Symfony路由组件在PHP应用程序中设置路由的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
加速PHP应用程序部署的秘密武器:Deployer加速PHP应用程序部署的秘密武器:DeployerJul 12, 2023 am 10:22 AM

加速PHP应用程序部署的秘密武器:Deployer一直以来,快速、高效地部署应用程序一直是软件开发团队的重要任务之一。在PHP开发中,部署应用程序通常涉及到上传文件、更新代码、配置环境等多个步骤。为了简化和加速这一过程,现代化的开发工具和技术逐渐被引入,而其中一个被广泛认可的秘密武器就是Deployer。Deployer是一个用于自动化应用程序部署的PHP库

如何使用Deployer部署PHP应用程序如何使用Deployer部署PHP应用程序Jul 12, 2023 pm 07:03 PM

如何使用Deployer部署PHP应用程序在现代软件开发过程中,自动化部署变得越来越重要。Deployer是一个简单而强大的PHP部署工具,它可以帮助我们轻松地部署PHP应用程序。本文将介绍如何使用Deployer来部署PHP应用程序,并提供一些代码示例。一、安装Deployer首先,我们需要通过Composer来安装Deployer。在命令行中运行以下命令

如何使用Memcache提升PHP应用程序的性能和可用性?如何使用Memcache提升PHP应用程序的性能和可用性?Nov 08, 2023 pm 09:57 PM

如何使用Memcache提升PHP应用程序的性能和可用性?引言:随着互联网应用程序的迅速发展和用户访问量的增加,提高应用程序的性能和可用性成为了开发者亟需解决的问题之一。其中,使用缓存是一种常见的优化手段。Memcache是一种常用的缓存技术,可以显著提升应用程序的性能和可用性。本文将介绍如何在PHP应用程序中使用Memcache,并给出具体的代码示例。安装

安全测试工具对PHP应用程序的应用安全测试工具对PHP应用程序的应用Aug 07, 2023 pm 07:36 PM

安全测试工具对PHP应用程序的应用随着互联网的发展,PHP应用程序在网络中的使用越来越普遍。然而,随之而来的安全威胁也日益增加。为了确保PHP应用程序的安全性,开发人员需要进行有效的安全测试。本文将介绍一些常用的安全测试工具,并提供相关的代码示例,以帮助开发人员更好地保护他们的应用程序。静态代码分析工具静态代码分析工具可以通过检查源代码中的潜在漏洞,并给出相

高效批量部署PHP应用程序:使用Deployer高效批量部署PHP应用程序:使用DeployerJul 12, 2023 am 08:36 AM

高效批量部署PHP应用程序:使用Deployer引言:随着云计算、容器化和微服务架构的兴起,现代应用程序的部署已经越来越复杂和繁琐。尤其是在开发团队需要频繁部署多个PHP应用程序的情况下,手动部署每个应用程序是非常耗时且容易出错的。为了解决这个问题,我们可以使用Deployer工具来自动化和简化PHP应用程序的部署过程。在本文中,我们将介绍Deployer的

Memcached缓存优化PHP应用程序的方法探讨Memcached缓存优化PHP应用程序的方法探讨Jun 20, 2023 am 08:43 AM

Memcached是一款开源的易于部署且轻量级的分布式缓存系统,被广泛地应用在Web应用程序的缓存中。它可以用来解决较大型Web应用程序中经常使用的数据库访问瓶颈问题,同时还能提高应用程序的性能。在本文中,我们将讨论如何使用Memcached优化PHP应用程序的缓存。使用缓存使用缓存可以有效地减少Web应用程序中数据库的查询次数。因为如果一个查询结果已经存在

如何通过缓存技术优化PHP应用程序响应时间?如何通过缓存技术优化PHP应用程序响应时间?Jun 20, 2023 pm 12:12 PM

近年来,随着Web应用程序越来越复杂,如何优化Web应用程序的响应时间成为了一个热门话题。其中,缓存技术是优化响应时间的一个重要手段。在本文中,我们将详细介绍如何通过缓存技术优化PHP应用程序响应时间。一、为什么需要缓存?当用户访问Web应用程序时,Web服务器会将PHP脚本解析成HTML代码,并返回给用户的浏览器。然而,如果PHP脚本非常复杂,在返回HTM

使用Symfony路由组件在PHP应用程序中设置路由使用Symfony路由组件在PHP应用程序中设置路由Sep 03, 2023 pm 10:37 PM

什么是Symfony路由组件?Symfony路由组件是一个非常流行的路由组件,它由多个框架改编而成,如果您希望在PHP应用程序中设置路由,它可以提供很大的灵活性。如果您已经构建了自定义PHP应用程序并正在寻找功能丰富的路由库,那么Symfony路由组件是最佳候选之一。它还允许您以YAML格式定义应用程序的路由。从安装和配置开始,我们将通过实际示例来演示该组件用于路由配置的各种选项。在本文中,您将了解到:Symfony路由组件的安装和配置如何设置基本路线如何从YAML文件加载路由将路由创建为注释:

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前By尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具