Maison  >  Article  >  développement back-end  >  Comment configurer le routage dans CakePHP ?

Comment configurer le routage dans CakePHP ?

WBOY
WBOYoriginal
2023-06-04 11:21:031145parcourir

CakePHP est un framework PHP populaire qui fournit diverses fonctionnalités et composants pour accélérer le développement d'applications Web. L'un des composants très utiles est le routage, qui est utilisé pour gérer les URL dans les applications Web.

Le routage fait référence au processus de mappage des requêtes d'URL aux composants ou actions correspondants dans votre application. Dans CakePHP, le gestionnaire de routes utilise des règles de routage pour identifier les URL et les analyser en contrôleurs et actions ou autres paramètres.

Dans cet article, nous examinerons en profondeur comment mettre en place des règles de routage dans CakePHP pour avoir un meilleur contrôle sur les URL de nos applications web.

  1. Règles de routage de base

Les règles de routage de base dans CakePHP mappent les URL aux contrôleurs et à leurs actions. Par défaut, CakePHP utilise le nom du contrôleur comme premier segment du chemin URL, suivi du nom de l'action à appeler dans le contrôleur.

Par exemple, si nous avons un contrôleur comme "ArticlesController" et qu'il a une action appelée "view", alors par défaut l'URL "/articles/view" sera mappée à cette action.

Si le nom du contrôleur est différent de celui indiqué dans le chemin de l'URL, ou si vous souhaitez utiliser un nom d'action différent, vous devez utiliser une règle de routage personnalisée.

  1. Règles de routage personnalisées

Pour définir des règles de routage personnalisées, ouvrez le fichier config/routes.php. Ce fichier contient toutes les règles de routage utilisées par le gestionnaire de routage.

Dans ce fichier, vous pouvez utiliser la méthode Router::connect() pour définir des règles de routage. Le premier paramètre de cette méthode est un modèle de chemin d'URL, qui utilise des espaces réservés pour représenter les contrôleurs et les actions. Le deuxième paramètre est le nom du contrôleur/de l'action à appeler.

Par exemple, si vous souhaitez mapper l'URL "/news/latest" à l'action "latest" de "NewsController", vous pouvez utiliser le code suivant :

Router::connect('/news/latest', array('controller' => 'News', 'action' => 'latest'));

Disons que vous avez un contrôleur Admin, qui a un fichier appelé action "dashboard", et que vous souhaitez mapper l'URL "/admin/dashboard" à l'action, vous pouvez utiliser le code suivant :

Router::connect('/admin/dashboard', array('controller' => 'Admin', 'action' => 'dashboard'));

Pour les espaces réservés, vous pouvez utiliser deux points (:) suivis du nom de l'espace réservé dans le formulaire de chemin d'URL, tel que ":id". Dans le nom du contrôleur/action, vous pouvez utiliser le nom $placeholder pour la variable.

Par exemple, si vous souhaitez mapper l'URL "/articles/123" à l'action "view" de "ArticlesController" et utiliser l'ID de l'article comme paramètre de l'action, vous pouvez utiliser le code suivant :

Router::connect('/articles/:id', array('controller' => 'Articles', 'action' => 'view'), array('pass' => array('id')));

Dans le code ci-dessus, nous utilisons ":id" comme espace réservé pour faire correspondre l'ID de l'article dans l'URL, et transmettons "id" comme option "pass" à l'action. Cela vous permet d'utiliser $this->request->params 'pass' dans le contrôleur pour accéder à l'ID de publication.

Veuillez noter que les règles de routage dans CakePHP sont analysées dans l'ordre dans lequel elles sont définies. Si vous définissez plusieurs règles de routage avec le même modèle de chemin d'URL, vous devez placer la règle la plus spécifique en premier pour garantir une résolution de routage correcte.

  1. Règles de routage nommées

Les règles de routage nommées sont un moyen de donner aux adresses de routage des noms faciles à retenir. Ces règles peuvent être définies à l'aide de la méthode Router::connectNamed() et en nommant les préfixes à l'aide de l'option $prefixes.

Par exemple, si vous avez un contrôleur nommé « utilisateur » et que vous souhaitez mapper l'URL « /u/123 » à l'action « afficher » de ce contrôleur et transmettre l'ID utilisateur comme paramètre de l'action. Vous pouvez utiliser le code suivant :

Router::connectNamed(array('id'));
Router::connect('/u/:id', array('controller' => 'User', 'action' => 'view'), array('id' => 'd+'));

Dans le code ci-dessus, nous définissons d'abord un préfixe de nom appelé "id" en utilisant la méthode Router::connectNamed(). Nous définissons ensuite le chemin de l'URL sur "/u/:id" et le mappons à l'action "view" du "UserController", en utilisant l'ID utilisateur comme paramètre de l'action. Enfin, nous utilisons une expression régulière pour restreindre le paramètre ID afin qu'il n'accepte que des nombres.

Maintenant, dans votre application, vous pouvez utiliser la méthode Router::url() pour générer des URL pour les routes nommées. Par exemple, utilisez le code suivant pour générer l'URL : "/u/123" :

Router::url(array('controller' => 'User', 'action' => 'view', 'id' => 123), array('named' => array('id')));

Dans le code ci-dessus, nous utilisons le préfixe "id" de la règle de routage nommée pour définir la valeur du paramètre ID.

Résumé

Dans CakePHP, le routage est un composant important pour la gestion du mappage d'URL. Il vous permet de personnaliser les URL de votre application et de gérer plus efficacement le routage de votre application.

À l'aide du gestionnaire de routes de CakePHP, vous pouvez définir des règles de routage personnalisées, gérer les règles de routage nommées et restreindre et valider facilement les paramètres de route à l'aide d'expressions régulières. Ces fonctionnalités offrent un meilleur contrôle et des URL faciles à utiliser pour améliorer l'expérience utilisateur de l'application.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn