• Laravel 8

    Cours Laravel 8 – la sécurité – gestion du profil et API

    Lorsqu’on installe Jetstream on n’obtient pas seulement une authentification complète avec enregistrement, connexion et déconnexion, vérification de l’email, oubli du mot de passe, comme on l’a vu dans les deux articles précédents. On obtient beaucoup plus comme on va le voir dans cet article. Déjà une gestion du profil de l’utilisateur qui peut ainsi modifier ses données personnelles, mais également la possibilité de passer par une authentification à deux facteurs qui devient de plus en plus à la mode. l’utilisateur peut en plus supprimer sa session ou carrément son compte. On verra également la possibilité de demander la confirmation du mot de passe pour l’accès à des pages sensibles. Pour…

  • Laravel 8

    Cours Laravel 8 – la sécurité – l’oubli du mot de passe

    Un mot de passe est plus facile à oublier qu’à retenir, d’autant qu’on en est littéralement submergé ! Toute application avec une authentification doit prévoir ce genre de situation et donner la possibilité aux utilisateurs de se sortir de ce mauvais pas. Le plus simple est de leur permettre de créer un nouveau mot de passe. Laravel est équipé pour cela et nous allons le voir dans ce chapitre. Le présent chapitre est une suite du précédent et il faut avoir mis en place ce qui concerne l’authentification avec l’installation de Jetstream. La base de données Avec les migrations réalisées dans le chapitre précédent il y a la table password_resets dans…

  • Laravel 8

    Cours Laravel 8 – la sécurité – l’authentification

    L’authentification constitue une tâche fréquente. En effet il y a souvent des parties d’un site qui ne doivent être accessibles qu’à certains utilisateurs, ne serait-ce que l’administration. La solution proposée par Laravel est d’une grande simplicité parce que tout est déjà préparé comme nous allons le voir dans ce chapitre. Au fil de l’avolution de Laravel ce domaine a connu plusieurs fois des changements. Ainsi avec Laravel 6 est apparu une nouveauté. Précédemment il y avait la commande php artisan make:auth pour générer les vues. Cette commande a disparu au profit d’un package à installer (laravel/ui). Mais les changements continuent parce que désormais on nous dit d’utiliser Jetstream. Je vais…

  • Laravel 8

    Cours Laravel 8 – les données – les ressources d’API

    Laravel permet de bâtir facilement des API à partir de ressource Eloquent. Voyons cela dans cet article. Les API REST REST (Representational State Transfer) est un style d’architecture pour constituer des API. Pour Laravel une API REST est : organisée autours de ressources sans persistance (aucune session) orientée client-serveur pouvant être mis en cache (donc une requête doit retourner toujours les mêmes résultats) retourner du JSON… Si vous n’êtes pas trop sûr de vos connaissances concernant les API REST je vous conseille ce cours. Pour continuer avec notre application de films on peut imaginer ce endpoint pour les informations de tous les films : GET /api/films [ { id: 1,…

  • Laravel 8

    Cours Laravel 8 – les données – le polymorphisme

    Lors des deux précédents chapitres on a vu les principales relations que nous offre Eloquent : hasMany et belongsToMany. Je ne vous ai pas parlé de la relation hasOne parce que c’est juste du hasMany limité à un seul enregistrement et est peu utilisé. Dans tous les cas qu’on a vus on considère 2 tables en relation, même lorsqu’un table pivot sert de lien entre les deux. Dans le présent chapitre on va envisager le cas où une table peut être en relation avec plusieurs autres tables, ce qui se nomme du polymorphisme. Un peu de théorie La relation 1:1 ou 1:n On a vu cette relation, en voici une…

  • Laravel 8

    Cours Laravel 8 – les données – la relation n:n

    Dans le précédent chapitre nous avons vu la relation de type 1:n, la plus simple et la plus répandue. Nous allons maintenant étudier la relation de type n:n, plus délicate à comprendre et à mettre en œuvre. Nous allons voir qu’Eloquent permet de simplifier la gestion de ce type de relation. On va continuer l’application de gestion de films, toujours avec des catégories, mais maintenant on va considérer qu’un film peut appartenir à plusieurs catégories, ce qui change pas mal de choses… Les données La relation n:n Imaginez une relation entre deux tables A et B qui permet de dire : je peux avoir une ligne de la table A…

  • Laravel 8

    Cours Laravel 8 – les données – la relation 1:n

    Pour le moment nous n’avons manipulé qu’une table avec Eloquent. Dans le présent chapitre nous allons utiliser deux tables et les mettre en relation. La relation la plus répandue et la plus simple entre deux tables est celle qui fait correspondre un enregistrement d’une table à plusieurs enregistrements de l’autre table, on parle de relation de un à plusieurs ou encore de relation de type 1:n. Nous allons poursuivre notre gestion de films. Comme nous en avons beaucoup nous éprouvons la nécessité de les classer en catégories : comédie, fantastique, drame, thriller… On va partir du projet dans l’état où on l’a laissé dans le précédent article. Il y a…

  • Laravel 8

    Cours Laravel 8 – les données – les ressources (2/2)

    Dans cet article nous allons terminer de coder la ressource que nous avons commencée dans le précédent. Il nous reste à voir comment créer et modifier un film. Créer un film Les routes Pour la création d’un film on va avoir deux routes : pour afficher le formulaire de création pour soumettre le formulaire Le contrôleur Dans le contrôleur ce sont les méthodes create et store qui sont concernées. On va donc les coder : use App\Http\Requests\Film as FilmRequest; ... public function create() { return view('create'); } public function store(FilmRequest $filmRequest) { Film::create($filmRequest->all()); return redirect()->route('films.index')->with('info', 'Le film a bien été créé'); } La vue index On a déjà codé la…

  • Laravel 8

    Cours Laravel 8 – les données – les ressources (1/2)

    Dans ce chapitre nous allons commencer à étudier les ressources qui permettent de créer des routes « CRUD » (Create, Read, Update, Delete) adaptées à la persistance de données. Comme exemple pratique nous allons prendre le cas d’une table de films. Les données On repart d’un Laravel vierge et on crée une base comme on l’a vu précédemment. Appelons la par exemple laravel8 pour faire original. On renseigne le fichier .env en conséquence : DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=laravel8 DB_USERNAME=root DB_PASSWORD= La migration On va créer avec Artisan le modèle Film en même temps que la migration : php artisan make:model Film --migration Pour faire simple on va se contenter de 3 colonnes…