Ce tutoriel en deux parties guide les débutants sur l'utilisation des files d'attente push avec Laravel pour les tâches d'arrière-plan, illustrées par un exemple de photo et un exemple de redimensionnement. Le redimensionnement des images prend du temps; Cette approche empêche les retards des utilisateurs en déchargeant la tâche. Nous tirons également parti de NGROK pour permettre les tests de file d'attente locaux.
Le code source complet est disponible sur GitHub. Alternativement, déployez sur un serveur en direct pour les tests.
Concepts clés
- Ce tutoriel montre la configuration de IronMQ avec Laravel pour gérer les processus d'arrière-plan (comme le redimensionnement d'image) via des files d'attente push. L'application finale comprend un formulaire de téléchargement de photos et de redimensionnement simple.
- La configuration consiste à installer Laravel, à ses dépendances, à créer un compte Iron.io et à utiliser Ngrok pour exposer votre environnement de développement local à Internet, permettant une interaction de file d'attente IronMQ lors des tests locaux.
- IronMQ simplifie la gestion des files d'attente. La création d'une file d'attente push nécessite de spécifier une URL d'abonnée - une URL que IronMQ appellera lorsqu'un travail sera disponible.
- Le didacticiel couvre la configuration IronMQ dans Laravel, y compris la création de files d'attente et d'abonnés, et l'installation des bibliothèques d'images IronMQ et d'intervention. La deuxième partie détaillera l'élaboration des applications et l'implémentation de la logique de l'emploi.
files d'attente et ironmq
Une file d'attente est un pipeline d'emplois. Les travaux sont traités séquentiellement dans l'ordre où ils sont ajoutés. Pousser les files d'attente, contrairement aux files d'attente de traction, aviser de manière proactive les abonnés lorsqu'un travail est prêt, éliminant le besoin d'un sondage constant. IronMQ est un service qui facilite ce système de file d'attente basé sur la poussée. Lors de la création d'une file d'attente push, vous définissez une URL d'abonnée; IronMQ envoie des données d'emploi à cette URL lorsqu'un travail devient disponible.
Pour une plongée plus profonde dans les files d'attente de travaux et les comparaisons de diverses solutions, reportez-vous à [cet article] (link_to_article_here - Remplacez par un lien réel si disponible).
Configuration et installation
Cette section détaille l'installation de Laravel, ses dépendances, la création d'un compte iron.io et la configuration de Ngrok.
laravel
-
Installez le compositeur.
-
Installez Laravel:
composer create-project laravel/laravel --prefer-dist
Accédez au répertoirelaravel
et exécutezphp artisan serve
. Accédez à votre installation de Laravel àhttp://localhost:8000
. -
Configuration de la base de données: utilisez MySQL. Créez une base de données et mise à jour
app/config/database.php
avec vos informations d'identification de base de données. Exécuterphp artisan migrate:install
. -
Modifier
app/views/welcome.blade.php
(ou équivalent) pour afficher un message confirmant votre configuration. -
Installez les bibliothèques d'images IronMQ et d'intervention: ajoutez-les à votre fichier
composer.json
:"require": { "laravel/framework": "^9.0", // or your Laravel version "iron-io/iron_mq": "^1.4", "intervention/image": "^2.7" },
Run
composer update
. Ensuite, configurez le package d'image d'intervention dansconfig/app.php
en ajoutant le fournisseur de services et alias comme documenté dans la documentation d'image d'intervention.
ngrok
Pour les tests locaux avec IronMQ, utilisez Ngrok pour exposer votre serveur local à Internet.
- Télécharger et installer ngrok.
- Exécuter
./ngrok 8000
(ou le port approprié si votre serveur Laravel en utilise un autre). Notez l'URL de transfert (par exemple,http://your-ngrok-url.ngrok.io
). Cette URL agira comme votre URL abonnée.
ironmq
-
Créez un compte et un projet Iron.io.
-
Obtenez votre identifiant de projet et votre jeton à partir du tableau de bord iron.io.
-
Configurez vos paramètres de file d'attente Laravel dans
config/queue.php
:'iron' => [ 'driver' => 'iron', 'project' => env('IRON_PROJECT_ID'), 'token' => env('IRON_TOKEN'), 'queue' => 'laravel', ],
Ajouter
IRON_PROJECT_ID
etIRON_TOKEN
à votre fichier.env
. -
Créez un abonné Push Fitre à l'aide de la commande Artisan:
php artisan queue:subscribe laravel http://your-ngrok-url.ngrok.io/queue/receive
Remplacer
http://your-ngrok-url.ngrok.io
par votre URL de transfert Ngrok. -
Ajoutez la route suivante à
routes/web.php
:Route::post('queue/receive', function () { return Queue::marshal(); });
Conclusion (partie 1)
Cette pièce couvre la configuration et l'installation des composants nécessaires. La deuxième partie se concentrera sur la création de l'application et la mise en œuvre du travail de redimensionnement de l'image.
Questions fréquemment posées (FAQ) (Cette section reste largement inchangée, car les informations sont toujours pertinentes.)
(La section FAQ existante est bien écrite et précise; aucune modification n'est nécessaire.)
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!

Le délai d'expiration de session absolue commence au moment de la création de session, tandis qu'un délai d'expiration inactif de session démarre au moment de la non-opération de l'utilisateur. Le délai d'expiration de session absolue convient aux scénarios où un contrôle strict du cycle de vie de la session est nécessaire, tels que les applications financières; Le délai d'attente de session inactif convient aux applications qui souhaitent que les utilisateurs maintiennent leur session active pendant longtemps, comme les médias sociaux.

La défaillance de la session du serveur peut être résolue en suivant les étapes: 1. Vérifiez la configuration du serveur pour vous assurer que la session est correctement définie. 2. Vérifiez les cookies des clients, confirmez que le navigateur le prend en charge et l'envoyez-le correctement. 3. Vérifiez les services de stockage de session, tels que Redis, pour vous assurer qu'ils fonctionnent normalement. 4. Examiner le code de demande pour assurer la logique de session correcte. Grâce à ces étapes, les problèmes de conversation peuvent être diagnostiqués et réparés efficacement et l'expérience utilisateur peut être améliorée.

Session_Start () IsCrucialInPhpFormanAgingUsersessions.1) ItinitiateSanEwSessionIfNoneExists, 2) ConsomaSanExistingSession, and3) SetSasessionCooKieforContinuityAcrossrequests, permettant aux applications liées à la réaction et à la personne.

La définition de l'indicateur httponly est cruciale pour les cookies de session car il peut effectivement empêcher les attaques XSS et protéger les informations de session utilisateur. Plus précisément, 1) l'indicateur httponly empêche JavaScript d'accéder aux cookies, 2) l'indicateur peut être réglé via Setcookies et Make_Response dans PHP et FLASK, 3) Bien qu'il ne puisse pas être empêché de toutes les attaques, elle devrait faire partie de la politique de sécurité globale.

PhpSessionsSsolvetheproblemOf-MainainingStateCrossMultiplehttprequestsByStoringDataontheserverAndassociatingitwithauniquesessionId.1) ils storentaserver, généralement infilesordatabases, et de lasse de lastoredinacookietatevevedata.2)

PhpSessionsCanstorestrings, Numbers, Arrays, Andobject.1.Strings: TextDatalikeUserames.2.Numbers: IntegersorFloatsForCounters.3.arrays: listslikeshoppingcarts.4.Objects: complexestructuresthataReSerialized.

TostartaphpSession, usessession_start () aTTheScript'sbeginning.1) PlaceItBeForeanyOutputToSetTheSessionCooKie.2) USESSIONSFORUSERDATALIKELOGINSTATUSORSHOPPINGSCARS.3) RegegeraSesessionIdStopreventfixationAtTACKS.4)

La régénération de session fait référence à la génération d'un nouvel ID de session et à l'invalidation de l'ancien ID lorsque l'utilisateur effectue des opérations sensibles en cas d'attaques fixes de session. Les étapes de mise en œuvre incluent: 1. Détectez les opérations sensibles, 2. Générer un nouvel ID de session, 3. Détruiser l'ancien ID de session, 4. Mettre à jour les informations de session côté utilisateur.


Outils d'IA chauds

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.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

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

Article chaud

Outils chauds

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Télécharger la version Mac de l'éditeur Atom
L'éditeur open source le plus populaire

VSCode Windows 64 bits Télécharger
Un éditeur IDE gratuit et puissant lancé par Microsoft

Dreamweaver Mac
Outils de développement Web visuel

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