Installez les composants de diffusion Pusher et Laravel et configurez Broadcast_Driver = Pusher et Queue_Connection; 2. Créez une application sur le site officiel du poussoir et obtenez des clés d'application, remplissez le fichier .env correspondant à la variable Pusher; 3. Activer BroadcastServiceProvider dans config / app.php et définir les canaux autorisés dans Routes / Channels.php; 4. Créez une classe d'événements qui met en ?uvre l'interface SHAUDBROADCAST, définissez le canal de diffusion et le format de données et déclenchez des événements dans le contr?leur; 5. Le frontal présente Pusher JS et Laravel Echo, initialisez la configuration et écoutez les canaux correspondants; 6. Démarrez le service, connectez-vous à l'utilisateur déclenche l'événement et vérifiez que la fonction de diffusion en temps réel est exécutée avec succès via la console du navigateur et le panneau Pusher Debug.
La configuration du poussoir avec Laravel est simple une fois que vous connaissez les étapes. Pusher permet la diffusion en temps réel des événements dans votre application Laravel - parfait pour les notifications, les applications de chat ou les mises à jour en direct. Voici comment le faire fonctionner.

? 1. Installez la diffusion de Pusher et Laravel
Tout d'abord, assurez-vous d'avoir les packages requis:
le compositeur nécessite un poussoir / pusteur-php-serveur
Laravel est livré avec un support de radiodiffusion, mais vous devez l'activer. Dans votre fichier .env
, définissez:

Broadcast_Driver = Pusher
Assurez-vous également que QUEUE_CONNECTION
est définie (généralement à sync
ou à database
) - Broadcasting fonctionne souvent aux c?tés des files d'attente.
? 2. Configurer les informations d'identification du poussoir
Allez sur pusher.com , créez un compte (si vous n'en avez pas) et créez une nouvelle application. Notez ces valeurs de la section "Applications":

-
PUSHER_APP_ID
-
PUSHER_APP_KEY
-
PUSHER_APP_SECRET
-
PUSHER_APP_CLUSTER
Ajoutez-les à votre fichier .env
:
Pusher_app_id = votre_app_id Pusher_app_key = your_app_key Pusher_app_secret = your_app_secret Pusher_app_cluster = votre_cluster
Laravel les utilise automatiquement via le fichier config/broadcasting.php
.
? Astuce: assurez-vous que
PUSHER_APP_KEY
correspond à ce que vous utilisez dans votre frontend (par exemple, en javascript).
? 3. Activer le fournisseur de services de diffusion
Dans config/app.php
, décommentez cette ligne dans le tableau providers
:
App \ Providers \ BroadcastServiceProvider :: Class,
Cela enregistre les itinéraires et la logique de la diffusion.
Ensuite, dans routes/channels.php
, vous pouvez définir les routes d'autorisation de diffusion (par exemple, pour les canaux privés).
Exemple:
Broadcast :: Channel ('User. {Id}', fonction ($ utilisateur, $ id) { return (int) $ user-> id === (int) $ id; });
? 4. Créer et diffuser un événement
Générer un événement:
PHP Artisan Make: événement Notifications
Ouvrez le fichier d'événements ( app/Events/NotificationSent.php
) et implémentez ShouldBroadcast
:
<? Php Namespace App \ Events; Utiliser illuminate \ Broadcasting \ Channel; Utiliser illuminate \ Broadcasting \ InteractWithSockets; Utiliser illuminate \ Broadcasting \ PresencECHANnel; Utiliser illuminate \ Broadcasting \ privateChannel; Utiliser illuminate \ contracts \ Broadcasting \ aitbroadcast; Utiliser illuminate \ Foundation \ Events \ Dispatchable; Utiliser illuminate \ queue \ serializesModels; Notifications de classe Implémentés devrait Broadcast { Utiliser la répartition, interactive avec des billets, serializesModels; Message public $; fonction publique __construct ($ message) { $ this-> message = $ message; } fonction publique Broadcaston () { return new privatechannel ('utilisateur.'. Auth () -> id ()); // ou publicChannel (?Notifications?) } fonction publique BroadcastWith () { return ['message' => $ this-> message]; } }
Maintenant, envoyez l'événement à partir d'un contr?leur:
événement (new notificationsSent (?Bonjour, utilisateur!?));
? 5. écoutez sur le frontend avec JavaScript
Incluez Pusher JS et Laravel Echo dans votre frontend (par exemple, dans resources/js/bootstrap.js
ou lame):
<script src = "https://js.pusher.com/8.2.0/pusher.min.js"> </ script> <script src = "https://cdn.jsdelivr.net/npm/laravel-echo@1.11.3/dist/echo.iife.js"> </ script>
Initialiser Laravel Echo:
<cript> window.echo = new echo ({ diffuseur: ?pusteur?, Clé: ?votre pusher-key?, // de pusher_app_key Cluster: ?votre cluster?, // par exemple, ?MT1? crypté: vrai, AuthendPoint: '/ Broadcasting / Auth', // pour les canaux privés auth: { En-têtes: { 'X-csrf-token': document.QuerySelector ('meta [name = "csrf-token"]'). GetAttribute ('contenu') } } }); // écoute la cha?ne privée Echo.private ('utilisateur.' Utilisateur) .Listen ('NotificationsSent', (e) => { Console.log (E.Message); }); </cript>
Assurez-vous d'avoir la balise CSRF Meta dans votre disposition:
<meta name = "csrf-token" content = "{{csrf_token ()}}">
? 6. Servir et tester
Exécutez votre application Laravel:
PHP Artisan Serve
Assurez-vous que vous êtes connecté (car les canaux privés dépendent de l'authentification), puis déclenchez l'événement.
Vérifiez la console du navigateur et les journaux Laravel ( storage/logs/laravel.log
) pour les erreurs.
Utilisez Pusher Debug Console (dans Pusher Dashboard) pour voir les événements en temps réel envoyés.
C'est ?a. Vous avez mis en place une diffusion en temps réel avec Pusher et Laravel. Ce n'est pas compliqué, mais les parties clés - corrigent .env
, la configuration des événements, l'authentification et la configuration d'écho frontal - doivent correspondre exactement.
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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Il existe trois fa?ons d'ajouter des règles de validation personnalisées dans Laravel: en utilisant les fermetures, les classes de règles et les demandes de formulaire. 1. Utilisez les fermetures pour être adaptées à la vérification légère, comme empêcher le nom d'utilisateur "admin"; 2. Créez des classes de règles (telles que ValidUsernamerule) pour rendre la logique complexe plus claire et maintenable; 3. Intégrer plusieurs règles dans les demandes de formulaire et gérer de manière centralisée la logique de vérification. Dans le même temps, vous pouvez définir des invites via des méthodes de messages personnalisés ou des réseaux de messages d'erreur entrants pour améliorer la flexibilité et la maintenabilité.

Les méthodes de base pour les applications Laravel pour implémenter le support multilingue comprennent: la définition des fichiers linguistiques, la commutation de langage dynamique, le routage des URL de traduction et la gestion des clés de traduction dans les modèles de lame. Tout d'abord, organisez les cha?nes de chaque langue dans les dossiers correspondants (tels que EN, ES, FR) dans le répertoire / Resources / Lang, et définissez le contenu de traduction en renvoyant le tableau associatif; 2. Traduire la valeur de clé via l'appel de fonction d'assistance \ _ \ _ () et utilisez l'application :: setLocale () pour combiner des paramètres de session ou de routage pour réaliser la commutation du langage; 3. Pour les URL de traduction, les chemins peuvent être définis pour différentes langues via des groupes de routage préfixés ou par voie d'alias dans les fichiers linguistiques mappés dynamiquement; 4. Gardez les touches de traduction concises et

TOWORKEFFECTECTEMENTSWitHPivottablesInLaravel, FirstAccessPivotDatauSingWithPivot () Orwithtimestamps (), ThepDateEntrieswitHupDateExistPivot (), ManagerLeshipSviaDeTache

LaravelprovidesAcleanAndFlexiblewayToSendNotificationsViamultipleChannelsLikeEmail, SMS, In-Appakets, andpushNotifications.youdefinenotificationChannelsInthevia () MethodofanotificationClass, ANDIDEFINENOTIFICATIONSECHETHODSLIKETOMAIL (), ToDatabase (), Ortovonage

ServiceProvider est le mécanisme de base utilisé dans le cadre Laravel pour l'enregistrement des services et l'initialisation de la logique. Vous pouvez créer un ServiceProvider personnalisé via la commande Artisan; 1. La méthode de registre est utilisée pour lier les services, enregistrer des singletons, définir des alias, etc., et d'autres services qui n'ont pas encore été chargés ne peuvent pas être appelés; 2. La méthode de démarrage s'exécute après que tous les services sont enregistrés et sont utilisés pour enregistrer les écouteurs d'événements, afficher les synthétiseurs, middleware et autres logiques qui dépend d'autres services; Les utilisations courantes incluent les interfaces et les implémentations de liaison, l'enregistrement des fa?ades, le chargement des configurations, l'enregistrement des instructions de ligne de commande et des composants de vue; Il est recommandé de centraliser les liaisons pertinentes à un ServiceProvider pour gérer et de faire attention à l'enregistrement

L'injection de dépendance gère automatiquement les dépendances de classe via des conteneurs de service dans Laravel sans de nouveaux objets manuels. Son noyau est l'injection de constructeur et l'injection de méthode, comme le passage automatiquement de l'instance de demande dans le contr?leur. Laravel analyse les dépendances via des invites de type et crée récursivement les objets requis. L'interface de liaison et l'implémentation peuvent être utilisées par le fournisseur de services pour utiliser la méthode Bind, ou singleton pour lier un singleton. Lorsque vous l'utilisez, vous devez vous assurer des invites de type, éviter les complications du constructeur, utiliser les liaisons contextuelles avec prudence et comprendre les règles d'analyse automatique. La ma?trise peut améliorer la flexibilité et la maintenance du code.

Les méthodes de base pour gérer les exceptions et les erreurs d'enregistrement dans les applications Laravel incluent: 1. Utilisez la classe App \ Exceptions \ Handler pour gérer de manière centralisée les exceptions non gérées, et enregistrer ou notifier les informations d'exception via la méthode Report (), telles que l'envoi de notifications Slack; 2. Utilisez Monolog pour configurer le système de journal, définissez le niveau de journal et la méthode de sortie dans config / logging.php et activer les journaux d'erreur et supérieurs à l'environnement de production. Dans le même temps, des informations d'exception détaillées peuvent être enregistrées manuellement dans report () en combinaison avec le contexte; 3. Personnalisez la méthode Render () pour retourner une réponse d'erreur de format JSON unifié, améliorant l'efficacité de collaboration de l'extrémité avant et arrière de l'API. Ces étapes sont

L'optimisation des performances de Laravel peut améliorer l'efficacité de l'application à travers quatre directions de base. 1. Utilisez le mécanisme de cache pour réduire les requêtes en double, stocker rarement la modification des données via Cache :: Remember () et d'autres méthodes pour réduire la fréquence d'accès à la base de données; 2. Optimiser la base de données de la requête du modèle aux requêtes, évitez les requêtes N 1, spécifiant les requêtes de champ, ajoutant des index, pagination de traitement et de lecture et de séparation d'écriture et réduire les goulots d'étranglement; 3. Utilisez des opérations longues telles que l'envoi d'e-mails et l'exportation de fichiers vers le traitement asynchrone de file d'attente, utilisez le superviseur pour gérer les travailleurs et configurer des mécanismes de réessayer; 4. Utilisez raisonnablement les fournisseurs de middleware et de services pour éviter une logique complexe et un code d'initialisation inutile et retarder le chargement des services pour améliorer l'efficacité du démarrage.
