À l'heure où j'écris ce tutoriel, la version 8 de Laravel vient de sortir et ce cours y est consacré.
L'installation
Nous allons donc attaquer notre blog en commençant par installer Laravel.
Il faut que j'aie composer ?
En effet, comme indiqué dans la doc de Laravel (Laravel Doc), nous installerons les dépendances de Laravel via composer. Normalement si tu attaques ce cours c'est que tu connais un peu composer. Pour te rafraîchir la mémoire, composer est un gestionnaire de dépendances PHP (équivalent de npm pour Javascript). Il gère aussi pour nous l'autoloader. Un petit lien vers la documentation si jamais : Documentation de composer.
Je vais faire un tour par là, ça ne me fera pas de mal !
Entendu. Une fois que c'est bon pour toi, on va pouvoir attaquer l'installation de Laravel.
Plusieurs solutions s'offrent à nous :
- Télécharger Laravel Installer via composer et effectuer ensuite toutes les opérations via cet installateur
- Utiliser composer comme habituellement
Je te propose d'installer Laravel via composer comme il est habituel de le faire.
Rendez-vous dans le terminal, la console, Windows powershell (ou même git bash si tu es sur Windows pour être sûr que tout fonctionne) pour effectuer les commandes que nous verrons tout au long de ce cours. Sur Windows si tu as des erreurs avec certaines commandes comme "ls", pas d'inquiétude. Cette commande sert à lister le contenu d'un dossier. Vérifie bien que tu utilises Windows Powershell (le logiciel au fond bleu !) ou Git Bash.
Premièrement, nous installons Laravel. La ligne suivante va créer un dossier nommé "blog" (que tu peux renommer comme bon te semble) dans ton dossier courant.
Comme lorsque tu utilises PHP sans framework, tu auras besoin d'un serveur pour pouvoir tester son site. Laravel intègre un serveur directement, mais si tu préfères utiliser WAMP ou équivalent, je te conseiller de faire la commande suivante dans le dossier qui va bien (www pour WAMP, htdocs pour MAMP...)
{"language":"","content":"composer create-project --prefer-dist laravel/laravel blog","filename":"CONSOLE : Installation de composer"}
Il y a également des outils plus avancés proposés par le framework qui permettent de gérer le serveur local sur lequel tu exécutes ton application comme Homestead ou Vagrant. Nous en parlerons dans un futur tutoriel au besoin.
Très bien j'ai tout compris. Je fais quoi maintenant ?
Nous allons maintenant regarder un peu la structure des dossiers de Laravel pour nous familiariser avec tout ça. Rendez-vous dans le dossier récemment créé :
{"language":"","content":"cd blog","filename":"CONSOLE"}
Découverte de l'architecture
Nous pouvons voir 10 dossiers (certains devraient ne pas être si inconnus que ça vu tu as déjà vu le modèle MVC et composer) et plusieurs fichiers notamment liés à la configuration. Décryptons tout ça :
- app : ce dossier contient clairement le coeur de notre application. Nous y écrirons nos contrôleurs, nos modèles... Tout ce qui concerne les lettres M et C du modèle MVC
- bootstrap : nous ne toucherons pas à ce dossier. Il est utilisé par Laravel pour initialiser l'application et optimiser les performances
- config : le nom est assez explicite. Nous retrouvons ici tous les fichiers de configuration sur lesquels nous pouvons agir pour paramétrer notre site
- database : ici nous aurons les fichiers qui agiront sur la création des tables en base de données
- public : c'est ici le point d'entrée de notre site web. Le fichier index.php est ici et nos assets (images, css, js...) seront dans ce dossier là. C'est normalement le seul dossier accessible pour les internautes
- resources : ici, c'est le dossier du V du modèle MVC. Nos vues et notre JS/CSS avant minification/bundlisation... sont ici ;)
- routes : assez explicite, ici a les fichiers dans lesquelles on indique nos routes
- storage : quand on donne aux utilisateurs la possibilité de mettre des fichiers sur notre site (upload d'image par exemple), ceux-ci seront stockés dans ce fichier. Il y a donc des droits particuliers dessus
- tests : un dossier pour les tests unitaires
- vendor : le fameux vendor géré par composer qu'on ne doit pas toucher et qui est dans le gitignore
Et concernant les fichiers à la racine ?
Tu parles sûrement des .env, composer.json, webpack.mix.js et autres... Ces fichiers sont pour la plupart liés à la configuration. Tu dois sûrement en connaitre : les fichiers liés à composer, ceux liés à npm (package.json), ceux liés à git.
Clairement ce qui va nous intéresser ici :
.env : c'est LE fichier de configuration qu'on ne peut éviter. On renseignera les identifiants de base de données, les clés API si on en a, le nom de l'application qu'on développe...
webpack.mix.js : typique de Laravel, ce fichier servira à paramétrer notre bundler/minifier et à agir sur nos fichiers javascript ou CSS durant l'étape de "compilation".
Parfait, commençons donc par toucher au .env pour configurer les accès à notre base de données.
Configuration
D'abord, je te laisse créer une base de données relationnelle dans MariaDB ou MySQL par exemple. Je rappelle que MariaDB est un fork de MySQL, donc dans tous les cas le type de connexion pour Laravel sera "mysql".
Ensuite, ouvre ton fichier .env dans ton éditeur favori et modifie les lignes suivantes par les valeurs liées à ta base de données :
{"language":"application/x-httpd-php","content":"DB_CONNECTION=mysql\nDB_HOST=127.0.0.1\nDB_PORT=3306\nDB_DATABASE=laravel\nDB_USERNAME=root\nDB_PASSWORD=","filename":".env"}
Tu peux aussi en profiter pour changer les lignes suivantes avec les valeurs que tu voudras. Par exemple :
{"language":"application/x-httpd-php","content":"APP_NAME=Blog\nAPP_ENV=local\nAPP_DEBUG=true\nAPP_URL=http://localhost:8888/blog/public","filename":".env"}
Je n'ai pas trop compris à quoi servaient ces lignes... Peux-tu me réexpliquer ?
Pas de soucis.
La variable APP_NAME est simplement le nom donné à l'application. Il sert si l'on garde les templates de base de Laravel dans les vues, notamment dans la balise title.
La variable APP_ENV peut prendre la valeur local ou production selon si l'on est en train d'utiliser le site en local ou bien en ligne.
APP_DEBUG quant à elle indique si l'on veut afficher les informations de débug sur les pages. Attention, activer cette option peut être très compromettante pour un site en ligne car les informations de connexion à la BDD sont inscrites en clair par exemple
APP_URL c'est l'URL qui permet d'accéder à l'application. Si l'on utilise MAMP, ce sera localhost:port/blog/public/. Si on utilise le serveur de Laravel (on voit ça juste après !), ce sera http://127.0.0.1:8000
Ok c'est plus clair ! J'ai créé une base de données et j'ai aussi configuré mon .env. Que dois-je faire maintenant ?
Maintenant, on va continué la configuration, mais rien de bien complexe ne t'inquiète pas.
On va aller dans le dossier config puis dans le fichier app.php.
Le fichier de configuration app.php définit les grandes variables de configuration communes à toute notre application
Tu peux remarquer ce genre de lignes :
{"language":"application/x-httpd-php","content":"'name' => env('APP_NAME', 'Laravel'),","filename":"app.php"}
En fait, c'est ici qu'on dit : notre variable de configuration appelée "name" a pour valeur ce qu'on a renseigné dans APP_NAME dans notre .env. Si l'on a renseigné dans notre .env, alors on prendra la valeur par défaut qui est ici Laravel.
Cette manière de faire permettra dans toute ton application d'accéder aux variables de configuration de manière simple.
N'hésite pas à lire les commentaires associés à chaque lignes de configuration, ils sont très explicites.
Nous allons maintenant modifier ce fichier pour renseigner la langue du site (très utile pour que les parties en Anglais de Laravel soient automatiquement en Français !) et le fuseau horaire.
Modifions donc les variables "timezone", "locale" et "fallback_locale" comme suit :
{"language":"application/x-httpd-php","content":"/*\n |--------------------------------------------------------------------------\n | Application Timezone\n |--------------------------------------------------------------------------\n |\n | Here you may specify the default timezone for your application, which\n | will be used by the PHP date and date-time functions. We have gone\n | ahead and set this to a sensible default for you out of the box.\n |\n */\n\n 'timezone' => 'Europe/Paris',\n\n /*\n |--------------------------------------------------------------------------\n | Application Locale Configuration\n |--------------------------------------------------------------------------\n |\n | The application locale determines the default locale that will be used\n | by the translation service provider. You are free to set this value\n | to any of the locales which will be supported by the application.\n |\n */\n\n 'locale' => 'fr',\n\n /*\n |--------------------------------------------------------------------------\n | Application Fallback Locale\n |--------------------------------------------------------------------------\n |\n | The fallback locale determines the locale to use when the current one\n | is not available. You may change the value to correspond to any of\n | the language folders that are provided through your application.\n |\n */\n\n 'fallback_locale' => 'fr',","filename":"app.php"}
Tu trouveras toutes les valeurs possibles pour Timezone à cette page : https://www.php.net/manual/fr/timezones.php
Ok parfait ! Maintenant, passons à l'exécution et voyons la page d'accueil de notre site web.
Pour ça, comme je l'ai dit, 2 solutions : si tu as MAMP, WAMP ou autre, rdv sur Localhost comme habituellement. Sinon, on peut lancer :
{"language":"shell","content":"php artisan serve","filename":"console"}
Artisan est un utilitaire de Laravel écrit en PHP qui nous simplifie la vie. Nous verrons quelques unes de ses fonctionnalités dans la suite de cours.
Et voilà, si tout marche bien, tu as ceci qui doit s'afficher (version 8 de Laravel) !
Mais attends, on vient de régler dans le fichier de configuration app.php la langue en Français... Tout est en Anglais. Tu serais pas en train de nous raconter des salades ?
En effet, la page d'accueil est en Anglais... Et malheureusement, on ne pourra pas y faire grand chose à moins de traduire à la main ce qui est indiqué. Cela est normal. En effet, cette page ne restera jamais sur le site web telle quelle : on modifiera notre index en fonction de ce qu'on veut afficher pour les internautes.
Par contre, si on inspecte la page d'accueil, on remarque quand même que notre modification de langue a fonctionné.
Tu peux aussi essayer de remettre à zéro tes configurations et on aura <html lang="en"> qui s'affichera.
Cependant, même si on a renseigné la langue à "fr", il faut télécharger les fichiers qui permettent de traduire les phrases de base de Laravel en Français. Pour ça, on va installer le dossier de langues "fr" qu'on va piocher de ce repo GitHub (auquel j'ai participé (oui je frime un peu)) :
https://github.com/Laravel-Lang/lang
On fait donc un :
{"language":"shell","content":"composer require laravel-lang/lang:~8.0","filename":""}
Puis on a juste à déplacer le dossier de langues "fr" de vendor à resources/lang/fr et de même avec le fichier fr.json qu'on mettra dans resources/lang.
Pour ça on va utiliser les quelques commandes ci-dessous :
{"language":"shell","content":"mkdir resources/lang/fr\nmv vendor/laravel-lang/lang/src/fr/* resources/lang/fr\nmv vendor/laravel-lang/lang/json/fr.json resources/lang/ \nls resources/lang/fr","filename":""}
La dernière ligne doit normalement t'afficher 5 fichiers :
auth.php passwords.php validation.php
pagination.php validation-inline.php
Oui c'est tout bon pour moi !
Au final, qu'avons-nous vu et fait dans cette partie ?
- Installation de Laravel
- Découverte de son architecture
- Création d'une base de données qui nous servira par la suite
- Configuration de la langue et des accès à la base de données
- Installation des fichiers de traduction Anglais vers Français
- Lancement du serveur via artisan
Nous allons maintenant attaquer avec du lourd ;). Nous allons commencer par la partie M du modèle MVC en voyant les migrations, les factories et les seedings. Avec ces outils, on ne touchera plus jamais à phpmyadmin (ou au code SQL) !
J'ai terminé cette partie