Etat d’esprit

Laravel est un framework d'application web à la syntaxe expressive et élégante.

Philosophie 

Laravel est un framework d'application web à la syntaxe expressive et élégante. Nous pensons que le développement doit être une expérience agréable et créative pour être vraiment épanouissant. Laravel tente de soulager le développement en facilitant les tâches courantes utilisées dans la majorité des projets web, telles que l'authentification, le routage, les sessions et la mise en cache.

Laravel vise à rendre le processus de développement agréable pour le développeur sans sacrifier les fonctionnalités de l'application. Des développeurs heureux font le meilleur code. À cette fin, nous avons essayé de combiner le meilleur de ce que nous avons vu dans d'autres framework web, y compris des frameworks mis en œuvre dans d'autres langages, tels que Ruby on Rails, ASP.NET MVC et Sinatra.

Laravel est accessible, tout en étant puissant, et fournit les outils puissants nécessaires à des applications robustes et de grande envergure. Une superbe inversion du conteneur de contrôle, un système de migration expressif et un support de test unitaire étroitement intégré vous donnent les outils nécessaires pour construire n'importe quelle application dont vous avez la charge.

Artisan Console

Artisan est l'interface en ligne de commande incluse avec Laravel. Elle fournit un certain nombre de commandes utiles qui peuvent vous aider pendant que vous construisez votre application. Pour afficher une liste de toutes les commandes disponibles dans Artisan, vous pouvez utiliser la commande “list”.

Voici les commandes supporté par artisan :

  clear-compiled       Remove the compiled class file

  down                 Put the application into maintenance mode

  env                  Display the current framework environment

  help                 Displays help for a command

  inspire              Display an inspiring quote

  list                 Lists commands

  migrate              Run the database migrations

  optimize             Cache the framework bootstrap files

  serve                Serve the application on the PHP development server

  test                 Run the application tests

  tinker               Interact with your application

  ui                   Swap the front-end scaffolding for the application

  up                   Bring the application out of maintenance mode

 auth

  auth:clear-resets    Flush expired password reset tokens

 cache

  cache:clear          Flush the application cache

  cache:forget         Remove an item from the cache

  cache:table          Create a migration for the cache database table

 config

  config:cache         Create a cache file for faster configuration loading

  config:clear         Remove the configuration cache file

 db

  db:seed              Seed the database with records

  db:wipe              Drop all tables, views, and types

 event

  event:cache          Discover and cache the application's events and listeners

  event:clear          Clear all cached events and listeners

  event:generate       Generate the missing events and listeners based on registration

  event:list           List the application's events and listeners

 key

  key:generate         Set the application key

 make

  make:channel         Create a new channel class

  make:command         Create a new Artisan command

  make:component       Create a new view component class

  make:controller      Create a new controller class

  make:event           Create a new event class

  make:exception       Create a new custom exception class

  make:factory         Create a new model factory

  make:job             Create a new job class

  make:listener        Create a new event listener class

  make:mail            Create a new email class

  make:middleware      Create a new middleware class

  make:migration       Create a new migration file

  make:model           Create a new Eloquent model class

  make:notification    Create a new notification class

  make:observer        Create a new observer class

  make:policy          Create a new policy class

  make:provider        Create a new service provider class

  make:request         Create a new form request class

  make:resource        Create a new resource

  make:rule            Create a new validation rule

  make:seeder          Create a new seeder class

  make:test            Create a new test class

 migrate

  migrate:fresh        Drop all tables and re-run all migrations

  migrate:install      Create the migration repository

  migrate:refresh      Reset and re-run all migrations

  migrate:reset        Rollback all database migrations

  migrate:rollback     Rollback the last database migration

  migrate:status       Show the status of each migration

 notifications

  notifications:table  Create a migration for the notifications table

 optimize

  optimize:clear       Remove the cached bootstrap files

 package

  package:discover     Rebuild the cached package manifest

 queue

  queue:failed         List all of the failed queue jobs

  queue:failed-table   Create a migration for the failed queue jobs database table

  queue:flush          Flush all of the failed queue jobs

  queue:forget         Delete a failed queue job

  queue:listen         Listen to a given queue

  queue:restart        Restart queue worker daemons after their current job

  queue:retry          Retry a failed queue job

  queue:table          Create a migration for the queue jobs database table

  queue:work           Start processing jobs on the queue as a daemon

 route

  route:cache          Create a route cache file for faster route registration

  route:clear          Remove the route cache file

  route:list           List all registered routes

 schedule

  schedule:run         Run the scheduled commands

 session

  session:table        Create a migration for the session database table

 storage

  storage:link         Create the symbolic links configured for the application

 stub

  stub:publish         Publish all stubs that are available for customization

 ui

  ui:auth              Scaffold basic login and registration views and routes

  ui:controllers       Scaffold the authentication controllers

 vendor

  vendor:publish       Publish any publishable assets from vendor packages

 view

  view:cache           Compile all of the application's Blade templates

  view:clear           Clear all compiled view files

Broadcasting

Dans de nombreuses applications web modernes, les WebSockets sont utilisés pour mettre en œuvre des interfaces utilisateur en temps réel et actualisées en direct. Lorsque certaines données sont mises à jour sur le serveur, un message est généralement envoyé via une connexion WebSocket pour être traité par le client. Cela offre une alternative plus robuste et plus efficace que d'interroger continuellement votre application pour connaître les changements.

Pour vous aider à construire ce type d'applications, Laravel facilite la "diffusion" de vos événements par le biais d'une connexion WebSocket. La diffusion de vos événements Laravel vous permet de partager les mêmes noms d'événements entre votre code côté serveur et votre application JavaScript côté client.

Cache

Laravel fournit une API expressive et unifiée pour différents backends de mise en cache. La configuration du cache se trouve à l'adresse config/cache.php. Dans ce fichier, vous pouvez spécifier le pilote de cache que vous souhaitez utiliser par défaut dans toute votre application. Laravel prend en charge les backends de mise en cache les plus courants tels que Memcached et Redis.

Le fichier de configuration du cache contient également diverses autres options, qui sont documentées dans le fichier, donc assurez-vous de lire ces options. Par défaut, Laravel est configuré pour utiliser le pilote de cache de fichiers, qui stocke les objets sérialisés et mis en cache dans le système de fichiers. Pour les applications plus importantes, il est recommandé d'utiliser un pilote plus robuste tel que Memcached ou Redis. Vous pouvez même configurer plusieurs configurations de cache pour le même pilote.

Collections

La classe Illuminate\Support\Collection fournit un support fluide et pratique pour travailler avec des tableaux de données. 

La classe Collection vous permet d'enchaîner ses méthodes pour effectuer un mappage fluide et une réduction du tableau sous-jacent. En général, les collections sont immuables, ce qui signifie que chaque méthode de collection renvoie une instance de collection entièrement nouvelle.

Events

Les événements de Laravel offrent une mise en œuvre simple des observateurs, vous permettant de souscrir et d'écouter les différents événements qui se produisent dans votre application. Les classes d'événements sont généralement stockées dans le répertoire app/Events, tandis que leurs observateurs sont stockés dans app/Listeners. Ne vous inquiétez pas si vous ne voyez pas ces répertoires dans votre application, car ils seront créés pour vous au fur et à mesure que vous générerez des événements et des auditeurs à l'aide des commandes de la console Artisan.

Les événements constituent un excellent moyen de découpler divers aspects de votre application, puisqu'un même événement peut avoir plusieurs écouteurs qui ne dépendent pas les uns des autres. Par exemple, vous pouvez souhaiter envoyer une notification Slack à votre utilisateur chaque fois qu'une commande a été expédiée. Au lieu de coupler votre code de traitement de commande à votre code de notification Slack, vous pouvez créer un événement OrderShipped, qu'un écouteur peut recevoir et transformer en une notification Slack.

File Storage

Laravel fournit une puissante abstraction de système de fichiers grâce au merveilleux paquet PHP Flysystem de Frank de Jonge. 

L'intégration Flysystem de Laravel fournit des pilotes simples à utiliser pour travailler avec les systèmes de fichiers locaux et Amazon S3. Mieux encore, il est étonnamment simple de passer d'une option de stockage à l'autre, car l'API reste la même pour chaque système.

Helpers

Laravel comprend une variété de fonctions PHP "d'aide" globales. Nombre de ces fonctions sont utilisées par le framework lui-même ; vous êtes toutefois libre de les utiliser dans vos propres applications si vous les trouvez pratiques.

HTTP Client

Laravel fournit une API minimale et expressive autour du client HTTP Guzzle, vous permettant d'effectuer rapidement des requêtes HTTP sortantes pour communiquer avec d'autres applications web. L'habillage de Laravel autour de Guzzle est axé sur les cas d'utilisation les plus courants et sur une expérience de développement exceptionnelle.

Avant de commencer, vous devez vous assurer que vous avez installé le paquet Guzzle en tant que dépendance de votre application. 

Mail

Laravel fournit une API propre et simple via la populaire bibliothèque SwiftMailer avec des pilotes pour SMTP, Mailgun, Postmark, Amazon SES et sendmail, vous permettant de commencer rapidement à envoyer des e-mails via un service local ou basé sur le cloud de votre choix.

Notifications

En plus de l'envoi de courriels, Laravel fournit un support pour l'envoi de notifications par différents canaux de distribution, y compris les e-mails, les SMS (via Vonage, anciennement connu sous le nom de Nexmo), et Slack. Les notifications peuvent également être stockées dans une base de données afin d'être affichées dans votre interface web.

En règle générale, les notifications doivent être des messages courts et informatifs qui informent les utilisateurs de quelque chose qui s'est produit dans votre application. Par exemple, si vous écrivez une application de facturation, vous pouvez envoyer une notification "Facture payée" à vos utilisateurs par courrier électronique et par SMS.

Package Development

Les paquets sont le principal moyen d'ajouter des fonctionnalités à Laravel. Les paquets peuvent être n'importe quoi, d'une excellente façon de travailler avec des dates comme Carbon, ou un framework de test BDD entier comme Behat.

Il existe différents types de paquets. Certains paquets sont autonomes, c'est-à-dire qu'ils fonctionnent avec n'importe quel framework PHP. Carbon et Behat sont des exemples de paquets autonomes. Chacun de ces paquets peut être utilisé avec Laravel en le demandant dans votre fichier composer.json.

Par contre, d'autres paquets sont spécifiquement destinés à être utilisés avec Laravel. Ces paquets peuvent avoir des routes, des contrôleurs, des vues et une configuration spécifiquement destinés à améliorer une application Laravel.

Queues

Les files d'attente Laravel fournissent une API unifiée à travers une variété de backends de files d'attente différents, tels que Beanstalk, Amazon SQS, Redis, ou même une base de données relationnelle. Les files d'attente vous permettent de reporter à une date ultérieure le traitement d'une tâche longue, telle que l'envoi d'un courriel. Le report de ces tâches fastidieuses accélère considérablement les requêtes web vers votre application.

Le fichier de configuration de la file d'attente est stocké dans config/queue.php. Dans ce fichier, vous trouverez les configurations de connexion pour chacun des pilotes de file d'attente inclus dans le framework, qui comprend une base de données, Beanstalkd, Amazon SQS, Redis, et un pilote synchrone qui exécutera les tâches immédiatement (pour une utilisation locale). Un pilote de file d'attente nul est également inclus, qui permet d'éliminer les travaux en attente.

Task Scheduling

Dans le passé, vous avez peut-être généré une entrée Cron pour chaque tâche que vous deviez programmer sur votre serveur. Cependant, cela peut rapidement devenir pénible, car votre calendrier de tâches n'est plus sous contrôle de la source et vous devez effectuer une opération de SSH sur votre serveur pour ajouter des entrées Cron supplémentaires.

Le planificateur de commandes de Laravel vous permet de définir de manière fluide et expressive votre planning de commandes au sein même de Laravel. Lorsque vous utilisez le planificateur, une seule entrée de Cron est nécessaire sur votre serveur. Votre planning de tâches est défini dans la méthode de planification du fichier app/Console/Kernel.php.

Certification Laravel

Il est possible de passer une certification pour valider vos compétences sur Larevel et devenir "Certified Laravel Developer".

Découvrir le certification Laravel.