路由

简而言之,路由就是将控制器与浏览器中输入的URL链接起来。现代网络应用需要漂亮的URL。这意味着从/index.php?product_id=23这样的URL转为/catalog/product/t-shirt这样的URL。这就是路由的作用。

Symfony 有一个强大的路由机制,让我们可以做到以下几点:

  • 创建映射到控制器的复杂路由
  • 在模板内生成URL
  • 在控制器内生成URL
  • 从不同地点加载路由资源

在 Symfony 中,路由的工作方式是所有的请求都通过app.php。然后,Symfony 核心要求路由器检查该请求。路由器会将传入的URL与特定的路由进行匹配,并返回有关该路由的信息。这些信息,包括应该执行的控制器。最后,Symfony 内核执行控制器,控制器返回一个响应对象。

所有的应用路由都是从一个路由配置文件加载的,通常是app/config/routing.yml文件,如我们的测试应用所示:

  1. app:
  2. resource: "@AppBundle/Controller/"
  3. type: annotation

App 只是众多可能的条目之一。它的资源值指向 AppBundle 控制器目录,类型设置为annotation,这意味着将读取类annotations来指定精确的路由。

我们可以用几种变化来定义一个路由。其中的一个变化如下块所示:

  1. // Basic Route Configuration
  2. /**
  3. * @Route("/")
  4. */
  5. public function homeAction()
  6. {
  7. // ...
  8. }
  9. // Routing with Placeholders
  10. /**
  11. * @Route("/catalog/product/{sku}")
  12. */
  13. public function showAction($sku)
  14. {
  15. // ...
  16. }
  17. // >>Required<< and Optional Placeholders
  18. /**
  19. * @Route("/catalog/product/{id}")
  20. */
  21. public function indexAction($id)
  22. {
  23. // ...
  24. }
  25. // Required and >>Optional<< Placeholders
  26. /**
  27. * @Route("/catalog/product/{id}", defaults={"id" = 1})
  28. */
  29. public function indexAction($id)
  30. {
  31. // ...
  32. }

前面的例子展示了几种定义路由的方法。有趣的是,有必要参数和可选参数的情况。如果我们考虑一下,从最新的例子中去掉 ID,就会和前面的例子用 sku 匹配。Symfony 路由器总是会选择第一个找到的匹配路由。我们可以通过在@Route注解上添加正则表达式要求来解决这个问题,如下所示:

  1. @Route(
  2. "/catalog/product/{id}",
  3. defaults={"id": 1},
  4. requirements={"id": "\d+"}
  5. )

关于控制器和路由,还有更多的内容要讲,一旦我们开始构建我们的应用程序,我们就会看到。