Maison > php教程 > PHP开发 > Résumé de la configuration du routage du framework Laravel et conseils de configuration

Résumé de la configuration du routage du framework Laravel et conseils de configuration

高洛峰
Libérer: 2016-12-27 11:12:49
original
1566 Les gens l'ont consulté

Routages de base

La grande majorité des itinéraires de votre application seront définis dans le fichier app/routes.php. L'itinéraire le plus simple dans Laravel consiste en un URI et un appel de fermeture.

Route GET de base

<span style="font-size: 16px;">Route::get(&#39;/&#39;, function()<br/>{<br/>return &#39;Hello World&#39;;<br/>});<br/></span>
Copier après la connexion

Route POST de base

<span style="font-size: 16px;">Route::post(&#39;foo/bar&#39;, function()<br/>{<br/>return &#39;Hello World&#39;;<br/>});<br/></span>
Copier après la connexion

Enregistrez-en une Route pour répondre à toutes les méthodes HTTP

<span style="font-size: 16px;">Route::any(&#39;foo&#39;, function()<br/>{<br/>   return &#39;Hello World&#39;;<br/>});<br/></span>
Copier après la connexion

Forcer l'accès à une route via HTTPS

<span style="font-size: 16px;">Route::get(&#39;foo&#39;, array(&#39;https&#39;, function()<br/>{<br/>    return &#39;Must be over HTTPS&#39;;<br/>}));<br/></span>
Copier après la connexion

Souvent, vous devez générer URL basées sur un itinéraire, vous pouvez le faire en utilisant la méthode URL::to :

<span style="font-size: 16px;">$url = URL::to(&#39;foo&#39;);<br/></span>
Copier après la connexion

Paramètres d'itinéraire

<span style="font-size: 16px;">Route::get(&#39;user/{id}&#39;, function($id)<br/>{<br/>return &#39;User &#39;.$id;<br/>});<br/></span>
Copier après la connexion

Paramètres d'itinéraire facultatifs

<span style="font-size: 16px;">Route::get(&#39;user/{name?}&#39;, function($name = null)<br/>{<br/>return $name;<br/>});<br/></span>
Copier après la connexion

Paramètres d'itinéraire facultatifs avec valeurs par défaut

<span style="font-size: 16px;">Route::get(&#39;user/{name?}&#39;, function($name = &#39;John&#39;)<br/>{<br/>return $name;<br/>});<br/></span>
Copier après la connexion

Itinéraire avec contraintes d'expression régulière

<span style="font-size: 16px;">Route::get(&#39;user/{name}&#39;, function($name)<br/>{<br/>//<br/>})<br/>->where(&#39;name&#39;, &#39;[A-Za-z]+&#39;);<br/>Route::get(&#39;user/{id}&#39;, function($id)<br/>{<br/>//<br/>})<br/>->where(&#39;id&#39;, &#39;[0-9]+&#39;);<br/></span>
Copier après la connexion

Filtres d'itinéraires

Les filtres d'itinéraires offrent un moyen simple de restreindre l'accès à des itinéraires spécifiques, que vous devez créer pour votre site. Très utile lors de l'authentification. zones. Le framework Laravel contient certains filtres de routage, tels que le filtre auth, le filtre auth.basic, le filtre invité et le filtre csrf. Ils sont stockés dans le fichier app/filters.php.

Définir un filtre de routage

Route::filter(&#39;old&#39;, function()
{
if (Input::get(&#39;age&#39;) < 200)
{
return Redirect::to(&#39;home&#39;);
}
});
Copier après la connexion

Si une réponse est renvoyée par un filtre de routage, cette réponse est considérée comme la réponse à cette requête, et le routage ne sera pas exécuté. after filter sera également désexécuté.

Route::get(&#39;user&#39;, array(&#39;before&#39; => &#39;old&#39;, function()
{
return &#39;You are over 200 years old!&#39;;
}));
Copier après la connexion

Spécifier un filtre de route pour une route

Route::get(&#39;user&#39;, array(&#39;before&#39; => &#39;auth|old&#39;, function()
{
return &#39;You are authenticated and over 200 years old!&#39;;
}));
Copier après la connexion

Spécifier les paramètres du filtre de route

Route::filter(&#39;age&#39;, function($route, $request, $value)
{
//
});
Route::get(&#39;user&#39;, array(&#39;before&#39; => &#39;age:200&#39;, function()
{
return &#39;Hello World&#39;;
}));
Copier après la connexion

Lorsque le filtre de route reçoit comme troisième réponse pour les paramètres $ réponse :

Route::filter(&#39;log&#39;, function($route, $request, $response, $value)
{
//
});
Copier après la connexion

Modèle pour les filtres d'itinéraires de base

Vous souhaiterez peut-être spécifier des filtres pour un ensemble d'itinéraires basés sur un URI.

Route::filter(&#39;admin&#39;, function()
{
//
});
Route::when(&#39;admin/*&#39;, &#39;admin&#39;);
Copier après la connexion

Dans l'exemple ci-dessus, le filtre admin sera appliqué à toutes les routes commençant par admin/. L'astérisque agit comme un caractère générique et correspondra à toutes les combinaisons de caractères.

Vous pouvez également contraindre les filtres de modèles en spécifiant des méthodes HTTP :

Route::when(&#39;admin/*&#39;, &#39;admin&#39;, array(&#39;post&#39;));
Copier après la connexion

Classes de filtrage

Pour les filtres avancés, vous pouvez utiliser une classe au lieu d'une fonction de fermeture. Étant donné que la classe de filtre est un conteneur IoC qui réside en dehors de l'application, vous pouvez utiliser l'injection de dépendances dans le filtre, ce qui facilite les tests.

Définir une classe de filtre

class FooFilter {
public function filter()
{
// Filter logic...
}
}
Copier après la connexion

Enregistrer un filtre basé sur une classe

Route::filter(&#39;foo&#39;, &#39;FooFilter&#39;);
Copier après la connexion

Routes nommées

Les routes nommées sont plus faciles à utiliser dans Spécifier itinéraires lors de la génération de redirections ou d'URL. Vous pouvez spécifier un nom pour la route comme ceci :

Route::get(&#39;user/profile&#39;, array(&#39;as&#39; => &#39;profile&#39;, function()
{
//
}));
Copier après la connexion

Vous pouvez également spécifier un nom de route pour la méthode du contrôleur :

  Route::get(&#39;user/profile&#39;, array(&#39;as&#39; => &#39;profile&#39;, &#39;uses&#39; => 
&#39;UserController@showProfile&#39;));
Copier après la connexion

Désormais, lorsque vous générez des URL ou des sauts en utilisant le nom d'un itinéraire :

$url = URL::route(&#39;profile&#39;);
$redirect = Redirect::route(&#39;profile&#39;);
Copier après la connexion

Vous pouvez utiliser la méthode currentRouteName pour obtenir le nom d'un itinéraire :

$name = Route::currentRouteName();
Copier après la connexion

Groupe d'itinéraires

Parfois, vous souhaiterez peut-être appliquer un filtre à un groupe d'itinéraires. Vous n'avez pas besoin de spécifier de filtres pour chaque route, vous pouvez utiliser des groupes de routes :

Route::group(array(&#39;before&#39; => &#39;auth&#39;), function()
{
Route::get(&#39;/&#39;, function()
{
// Has Auth Filter
});
Route::get(&#39;user/profile&#39;, function()
{
// Has Auth Filter
});
});
Copier après la connexion

Routage de sous-domaine

Le routage Laravel peut également gérer les sous-domaines avec caractère générique et obtenir le caractère générique du nom de domaine Paramètres :

Enregistrer la route du sous-domaine

Route::group(array(&#39;domain&#39; => &#39;{account}.myapp.com&#39;), function()
{
Route::get(&#39;user/{id}&#39;, function($account, $id)
{
//
});
});
Copier après la connexion

Préfixe de la route

Un groupe de routes peut ajouter un préfixe au groupe de routes en utilisant l'option préfixe dans le tableau d'attributs :

Ajouter un préfixe au groupe de routes

Route::group(array(&#39;prefix&#39; => &#39;admin&#39;), function()
{
Route::get(&#39;user&#39;, function()
{
//
});
});
Copier après la connexion

Liaison de modèle de route

La liaison de modèle fournit un moyen simple d'injecter des modèles dans les routes. Par exemple, au lieu de simplement injecter l'ID d'un utilisateur, vous pouvez injecter une instance entière de modèle utilisateur basée sur un ID spécifié. Utilisez d'abord la méthode Route::model pour spécifier le modèle requis :

Liez une variable au modèle

Route::model(&#39;user&#39;, &#39;User&#39;);
Copier après la connexion

Ensuite, définissez une route contenant le paramètre {user} :

Route::get(&#39;profile/{user}&#39;, function(User $user)
{
//
});
Copier après la connexion

Puisque nous avons lié le paramètre {user} au modèle User, une instance User sera injectée dans la route. Ainsi, par exemple, une requête pour profile/1 injectera une instance User avec l’ID 1.

Remarque : Si cette instance de modèle n'est pas trouvée dans la base de données, une erreur 404 sera générée.

Si vous souhaitez spécifier votre propre comportement qui n'est pas trouvé, vous pouvez passer une fermeture comme troisième argument à la méthode model :

Route::model(&#39;user&#39;, &#39;User&#39;, function()
{
throw new NotFoundException;
});
Copier après la connexion

Parfois, vous souhaitez utiliser votre propre méthode Pour traiter les paramètres de l'itinéraire, vous pouvez utiliser la méthode Route::bind :

Route::bind(&#39;user&#39;, function($value, $route)
{
return User::where(&#39;name&#39;, $value)->first();
});
Copier après la connexion

Déclenche une erreur 404

Il existe deux façons de déclencher manuellement une erreur 404 dans l'itinéraire. Tout d'abord, vous pouvez utiliser la méthode App::abort :

App::abort(404);
Copier après la connexion

Deuxièmement, vous pouvez lancer une instance de SymfonyComponentHttpKernelExceptionNotFoundHttpException.

Plus d'informations sur la gestion des exceptions 404 et l'utilisation de réponses personnalisées pour ces erreurs sont disponibles dans le chapitre Erreurs.

Routage vers les contrôleurs

Laravel vous permet non seulement d'acheminer vers des fermetures, mais également vers des classes de contrôleurs, et vous permet même de créer des contrôleurs de ressources

Plus d'informations veuillez accéder. documentation du contrôleur.

Pour plus d'articles liés au résumé de la configuration du routage du framework Laravel et aux conseils de configuration, veuillez faire attention au site Web PHP chinois !

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Recommandations populaires
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal