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.
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".