acme_admin_dashboard:
pattern: /{_locale}/admin
defaults: { _controller: AcmeBundle:Admin:dashboard }
Je veux que cet itinéraire soit accessible à /en/admin
et /en/admin/
. Comment pourrais-je y parvenir?
J'aime la réponse de @ Kuchengeschmack ( https://stackoverflow.com/a/11078348/593957 ) car elle ne déclenche pas de redirections externes.
Voici une version yaml:
acme_admin_dashboard:
pattern: /{_locale}/admin{trailingSlash}
defaults: { _controller: AcmeBundle:Admin:dashboard, trailingSlash : "/" }
requirements: { trailingSlash : "[/]{0,1}" }
Tapez simplement:
/**
* @Route("/route/of/some/page/")
*/
alors
www.example.com/route/of/some/page
et
www.example.com/route/of/some/page/
sont acceptés ...
J'ai trouvé une solution pour ajouter une barre oblique de fin à un itinéraire.
signifie que les deux liens fonctionnent www.example.com/route/of/some/page
et www.example.com/route/of/some/page/
. Vous pouvez le faire de cette façon:
si votre itinéraire ressemble
/**
* @Route("/route/of/some/page")
*/
public function pageAction() {
changer en
/**
* @Route("/route/of/some/page{trailingSlash}", requirements={"trailingSlash" = "[/]{0,1}"}, defaults={"trailingSlash" = "/"})
*/
public function pageAction() {
Vous pouvez également simplement utiliser la règle de réécriture dans le fichier .htaccess:
Supposons que vous ayez défini un itinéraire comme ceci:
news:
url: /news
param: { module: news, action: index }
Cela correspondra par http: //something.something/news , mais pas par http: //something.something/news/ Vous pouvez ajouter un itinéraire supplémentaire avec un barre oblique de fin, mais vous pouvez également simplement utiliser cette règle de réécriture dans le fichier .htaccess:
RewriteRule ^(.+)/$ http://%{HTTP_Host}/$1 [R=301,L]
http://symfony-blog.driebit.nl/2010/07/url-routes-with-or-without-a-trailing-slash/
J'ai piraté la ligne suivante dans le contrôleur frontal (app.php/app_dev.php)
$_SERVER['REQUEST_URI'] = preg_replace('|/$|', '', $_SERVER['REQUEST_URI'], 1);
avant $request = Request::createFromGlobals()
Route:
remove_trailing_slash:
path: /{url}
defaults: { _controller: AppBundle:Redirecting:removeTrailingSlash }
requirements:
url: .*/$
methods: [GET]
Contrôleur:
// src/AppBundle/Controller/RedirectingController.php
namespace AppBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Request;
class RedirectingController extends Controller
{
public function removeTrailingSlashAction(Request $request)
{
$pathInfo = $request->getPathInfo();
$requestUri = $request->getRequestUri();
$url = str_replace($pathInfo, rtrim($pathInfo, ' /'), $requestUri);
return $this->redirect($url, 301);
}
}
En savoir plus: http://symfony.com/doc/current/routing/redirect_trailing_slash.html
Pour les nouvelles versions SF:
Par défaut, le composant Symfony Routing requiert que les paramètres correspondent au chemin regex suivant: [^/]+
. Cela signifie que tous les caractères sont autorisés sauf /
.
Vous devez explicitement autoriser /
pour faire partie de votre paramètre en spécifiant un chemin d'expression rationnelle plus permissif.
YAML:
_hello:
path: /hello/{username}
defaults: { _controller: AppBundle:Demo:hello }
requirements:
username: .+
XML:
<routes xmlns="http://symfony.com/schema/routing"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://symfony.com/schema/routing http://symfony.com/schema/routing/routing-1.0.xsd">
<route id="_hello" path="/hello/{username}">
<default key="_controller">AppBundle:Demo:hello</default>
<requirement key="username">.+</requirement>
</route>
</routes>
PHP:
use Symfony\Component\Routing\RouteCollection;
use Symfony\Component\Routing\Route;
$collection = new RouteCollection();
$collection->add('_hello', new Route('/hello/{username}', array(
'_controller' => 'AppBundle:Demo:hello',
), array(
'username' => '.+',
)));
return $collection;
Annotations:
/**
* @Route("/hello/{username}", name="_hello", requirements={"username"=".+"})
*/
public function helloAction($username)
{
// ...
}