Maison développement back-end tutoriel php Modèle de conception de référentiel démystifié

Modèle de conception de référentiel démystifié

Feb 21, 2025 am 08:54 AM

Repository Design Pattern Demystified

Points de base

  • Le modèle d'entrepôt agit comme un intermédiaire entre l'application et la source de données, permettant la construction d'une architecture découplée pour atteindre l'évolutivité sans avoir besoin de dépendances à code dur.
  • Ce mode permet à l'application de se concentrer sur la réception et l'envoi de données pour enregistrer sans prêter attention aux détails de la source de données. Il le fait via une API publique (interface) à travers laquelle tous les utilisateurs communiquent avec la source de données.
  • Bien que le modèle d'entrepôt offre des avantages tels que la séparation des préoccupations et la facilité des tests unitaires, il ajoute également une couche d'abstraction, qui peut compliquer de petites applications.
  • La mise en œuvre du modèle d'entrepôt nécessite une injection de dépendance, ce qui permet à l'entrepôt de données d'être lié à l'interface d'entrepôt. Cela évite le couplage codé dur et facilite la programmation orientée vers l'interface.

Quel est le modèle d'entrepôt?

En termes simples, il s'agit d'une implémentation de la couche intermédiaire entre l'application et la source de données. Aucune des parties n'a besoin de se connaître pour effectuer leurs tâches respectives, ce qui nous permet d'avoir une architecture découplée qui aide à évoluer dans de grandes applications sans dépendances codées en dur.

Pourquoi devriez-vous y prêter attention?

Comprenons cela avec un exemple. Supposons que nous construisions une boutique en ligne vendant des bonbons à saveur d'orange. C'est un petit magasin qui maintient le stock local, nous n'avons donc rien de sophistiqué. Les applications de magasin ne peuvent se connecter qu'à la base de données et prendre des commandes en ligne en fonction de l'inventaire existant. Cela fonctionnera bien car le magasin n'a qu'un seul entrepôt d'approvisionnement et des zones d'exploitation limitées. Mais que se passe-t-il si le magasin veut étendre sa zone d'exploitation? Les magasins peuvent vouloir se développer dans une autre ville ou à travers le pays, et avoir un système d'inventaire central sera très gênant.

Si nous utilisons toujours le modèle de données, notre application sera quelque peu étroitement couplée. Les applications de magasin doivent connaître chaque source de données avec laquelle il doit interagir, ce qui est une mauvaise conception d'applications. Le travail d'une application StoreFront est de permettre aux clients de commander des bonbons, la demande ne devrait pas se soucier de la source de données, elle ne devrait pas suivre toutes les différentes sources de données. C'est là que les entrepôts de données entrent en jeu. Selon le modèle d'entrepôt, une API publique est exposée via une interface et chaque consommateur (dans ce cas notre application de magasin) l'utilise pour communiquer avec la source de données. Quelle source de données à utiliser ou comment y connecter n'a rien à voir avec l'application. L'application ne se soucie que des données qu'il obtient et des données qu'il envoie pour enregistrer.

Une fois le modèle d'entrepôt implémenté, un entrepôt peut être créé pour chaque source de données. Les applications de magasinage n'ont plus besoin de suivre les sources de données, elles utilisent simplement l'API du référentiel pour obtenir les données dont ils ont besoin.

Est-ce une panacée?

Non, ce n'est pas le cas. Comme chaque modèle de conception, il a ses avantages et ses inconvénients.

PROS:

  • Séparation des préoccupations; L'application n'a pas besoin de comprendre ou de suivre toutes les sources de données.
  • permet des tests unitaires faciles, car le référentiel est lié à une interface qui injecte la classe au moment de l'exécution.
  • Dry (ne vous répétez pas) Conception, le code pour interroger et obtenir des données à partir de la source de données ne sera pas répété.

Inconvénients:

  • Ajoutez une autre couche d'abstraction, ajoutant un certain niveau de complexité, ce qui le rend trop complexe pour les petites applications.

Comment faire?

Regardons un exemple de code simple. J'utiliserai Laravel dans mon exemple pour profiter de son excellente fonctionnalité d'injection de dépendance. Si vous utilisez un cadre PHP moderne, il devrait déjà avoir un conteneur d'injection / IOC de dépendance. La mise en œuvre du modèle d'entrepôt nécessite une injection de dépendance, car sans elle, vous ne pourrez pas lier votre entrepôt de données à une interface d'entrepôt, et l'idée est une programmation orientée vers l'interface pour éviter le couplage codé en dur. Si vous n'utilisez aucun framework ou si le cadre de votre choix n'a pas de conteneur IOC, vous pouvez utiliser un conteneur IOC standard (voir note de bas de page).

Commençons. Tout d'abord, nous avons configuré notre espace de noms et notre autoadad dans Composer. Ouvrez Composer.json et ajoutez PSR-4 Autoload à notre espace de noms (dans le nœud Autoload, immédiatement après classMap).

    "autoload": {
        "classmap": [
            "app/commands",
            "app/controllers",
            "app/models",
            "app/database/migrations",
            "app/database/seeds",
            "app/tests/TestCase.php"
        ],
        "psr-4": {
            "RocketCandy\": "app/RocketCandy"
        }
    },
Copier après la connexion
Copier après la connexion

Après enregistrer, exécutez composer dump-autoload -o dans le terminal pour enregistrer le chargement automatique du nouvel espace de noms. Créer app/RocketCandy/Repositories/OrangeCandyRepository/ dans OrangeCandyRepository.php. Ce sera notre interface de référentiel.

<?php
namespace RocketCandy\Repositories\OrangeCandyRepository;

interface OrangeCandyRepository {

    public function get_list( $limit = 0, $skip = 0 );

    public function get_detail( $candy_id = 0 );

}
Copier après la connexion

Maintenant que nous avons l'interface, nous pouvons créer un référentiel. Créer app/RocketCandy/Repositories/OrangeCandyRepository/ dans CityAOrangeCandyRepository.php.

<?php
namespace RocketCandy\Repositories\OrangeCandyRepository;

class CityAOrangeCandyRepository implements OrangeCandyRepository {

    public function get_list( $limit = 0, $skip = 0 ) {
        // 查询数据源并获取糖果列表
    }

    public function get_detail( $candy_id = 0 ) {
        // 查询数据源并获取糖果详情
    }

}
Copier après la connexion

Pour lier le référentiel CityAOrangeCandyRepository à l'interface OrangeCandyRepository, nous utiliserons le conteneur IOC de Laravel. Ouvrez app/start/global.php et ajoutez ce qui suit à la fin du fichier.

//OrangeCandyRepository
App::bind(
    'RocketCandy\Repositories\OrangeCandyRepository\OrangeCandyRepository',
    'RocketCandy\Repositories\OrangeCandyRepository\CityAOrangeCandyRepository'
);
Copier après la connexion

Remarque: je n'ai placé les liaisons IOC que dans global.php pour la démonstration. Idéalement, ceux-ci doivent être placés dans leurs propres fichiers séparés où vous pouvez mettre toutes les liaisons IOC, puis charger ce fichier ici dans global.php ou vous pouvez créer un fournisseur de services pour enregistrer chaque liaison IOC. Vous pouvez en savoir plus ici.

Maintenant, nous pouvons utiliser le référentiel via l'interface. Dans app/controllers/ situé dans CandyListingController.php.

    "autoload": {
        "classmap": [
            "app/commands",
            "app/controllers",
            "app/models",
            "app/database/migrations",
            "app/database/seeds",
            "app/tests/TestCase.php"
        ],
        "psr-4": {
            "RocketCandy\": "app/RocketCandy"
        }
    },
Copier après la connexion
Copier après la connexion

Ici, nous injectons l'interface OrangeCandyRepository dans notre contrôleur et stockons sa référence d'objet dans une variable de classe qui peut désormais être utilisée par n'importe quelle fonction du contrôleur pour interroger les données. Puisque nous lions l'interface OrangeCandyRepository au référentiel CityAOrangeCandyRepository, ce sera comme nous utilisons directement le référentiel CityAOrangeCandyRepository.

Ainsi, maintenant, le type et le type de source de données sont les seules préoccupations de CityAOrangeCandyRepository. Notre application ne connaît que l'interface OrangeCandyRepository et son API exposée, et chaque référentiel qui les implémente doit se conformer à cette API. L'entrepôt est analysé à partir du conteneur IOC à l'exécution, ce qui signifie que la liaison entre les entrepôts de l'interface peut être définie au besoin. La source de données peut désormais être une base de données, des services Web ou un pipeline Hyperdata interdimensionnel.

Tous les cas ne s'appliquent pas

Comme je l'ai mentionné dans les inconvénients du modèle de référentiel, il ajoute une certaine complexité à l'application. Donc, si vous faites une petite application et que vous ne le voyez pas évoluer au point où il est grand (peut nécessiter plusieurs sources de données), il est préférable de ne pas les implémenter et de s'en tenir au modèle de données à l'ancienne. Comprendre quelque chose est différent de savoir quand l'utiliser. Il s'agit d'un modèle de conception très pratique qui évite beaucoup de problèmes lors de la création d'applications et lorsque vous devez maintenir ou étendre (ou réduire) les applications, mais ce n'est pas une panacée pour toutes les applications.

J'ai utilisé le code spécifique de Laravel pour démontrer l'implémentation ci-dessus, mais il est assez simple et similaire pour tout bon conteneur IOC. Des questions? Veuillez le faire dans les commentaires ci-dessous.

Note de bas de page:

  • Voici quelques bibliothèques de conteneurs IOC que vous pouvez utiliser si votre framework n'a pas ou si vous n'utilisez pas le framework:

    • Ornodi
    • ray.di
    • auryn
    • DICE
    • seau
    • ding
  • lecture suggérée:

    • Conception entraînée par le domaine Rapidement
    • Conception axée sur le domaine par Eric Evans

Des questions fréquemment posées sur le modèle d'entrepôt

(Cette partie du contenu est fortement coïncidente avec le texte d'origine. Pour éviter la duplication, il est omis ici. La section FAQ dans le texte d'origine a inclus une explication complète du modèle d'entrepôt.)

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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 !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Sujets chauds

Tutoriel Java
1662
14
Tutoriel PHP
1262
29
Tutoriel C#
1235
24
Expliquez différents types d'erreur dans PHP (avis, avertissement, erreur mortelle, erreur d'analyse). Expliquez différents types d'erreur dans PHP (avis, avertissement, erreur mortelle, erreur d'analyse). Apr 08, 2025 am 12:03 AM

Il existe quatre principaux types d'erreur dans PHP: 1.Notice: Le moins, n'interrompra pas le programme, comme l'accès aux variables non définies; 2. AVERTISSEMENT: grave que d'avis, ne résiliera pas le programme, comme ne contenant aucun fichier; 3. FatalError: le plus grave, finira le programme, comme appeler aucune fonction; 4. PARSEERROR: ERREUR SYNTAXE, EVERA ENCORE LE PROGRAMME EST EXECULTÉ, comme oublier d'ajouter la balise de fin.

Expliquez le hachage de mot de passe sécurisé dans PHP (par exemple, Password_Hash, Password_verify). Pourquoi ne pas utiliser MD5 ou SHA1? Expliquez le hachage de mot de passe sécurisé dans PHP (par exemple, Password_Hash, Password_verify). Pourquoi ne pas utiliser MD5 ou SHA1? Apr 17, 2025 am 12:06 AM

Dans PHP, Password_Hash et Password_verify Les fonctions doivent être utilisées pour implémenter le hachage de mot de passe sécurisé, et MD5 ou SHA1 ne doit pas être utilisé. 1) Password_hash génère un hachage contenant des valeurs de sel pour améliorer la sécurité. 2) Password_verify Vérifiez le mot de passe et assurez-vous la sécurité en comparant les valeurs de hachage. 3) MD5 et SHA1 sont vulnérables et manquent de valeurs de sel, et ne conviennent pas à la sécurité de mot de passe moderne.

PHP et Python: comparaison de deux langages de programmation populaires PHP et Python: comparaison de deux langages de programmation populaires Apr 14, 2025 am 12:13 AM

PHP et Python ont chacun leurs propres avantages et choisissent en fonction des exigences du projet. 1.Php convient au développement Web, en particulier pour le développement rapide et la maintenance des sites Web. 2. Python convient à la science des données, à l'apprentissage automatique et à l'intelligence artificielle, avec syntaxe concise et adaptée aux débutants.

PHP en action: Exemples et applications du monde réel PHP en action: Exemples et applications du monde réel Apr 14, 2025 am 12:19 AM

PHP est largement utilisé dans le commerce électronique, les systèmes de gestion de contenu et le développement d'API. 1) E-commerce: Utilisé pour la fonction de panier et le traitement des paiements. 2) Système de gestion du contenu: utilisé pour la génération de contenu dynamique et la gestion des utilisateurs. 3) Développement des API: Utilisé pour le développement de l'API RESTful et la sécurité de l'API. Grâce à l'optimisation des performances et aux meilleures pratiques, l'efficacité et la maintenabilité des applications PHP sont améliorées.

Quelles sont les méthodes de demande HTTP (obtenir, publier, mettre, supprimer, etc.) et quand chacune devrait être utilisée? Quelles sont les méthodes de demande HTTP (obtenir, publier, mettre, supprimer, etc.) et quand chacune devrait être utilisée? Apr 09, 2025 am 12:09 AM

Les méthodes de demande HTTP incluent GET, Publier, Put and Delete, qui sont utilisées pour obtenir, soumettre, mettre à jour et supprimer respectivement les ressources respectivement. 1. La méthode GET est utilisée pour obtenir des ressources et convient aux opérations de lecture. 2. La méthode post-post est utilisée pour soumettre des données et est souvent utilisée pour créer de nouvelles ressources. 3. La méthode de put est utilisée pour mettre à jour les ressources et convient aux mises à jour complètes. 4. La méthode de suppression est utilisée pour supprimer les ressources et convient aux opérations de suppression.

PHP: un langage clé pour le développement Web PHP: un langage clé pour le développement Web Apr 13, 2025 am 12:08 AM

PHP est un langage de script largement utilisé du côté du serveur, particulièrement adapté au développement Web. 1.Php peut intégrer HTML, traiter les demandes et réponses HTTP et prend en charge une variété de bases de données. 2.PHP est utilisé pour générer du contenu Web dynamique, des données de formulaire de traitement, des bases de données d'accès, etc., avec un support communautaire solide et des ressources open source. 3. PHP est une langue interprétée, et le processus d'exécution comprend l'analyse lexicale, l'analyse grammaticale, la compilation et l'exécution. 4.PHP peut être combiné avec MySQL pour les applications avancées telles que les systèmes d'enregistrement des utilisateurs. 5. Lors du débogage de PHP, vous pouvez utiliser des fonctions telles que error_reportting () et var_dump (). 6. Optimiser le code PHP pour utiliser les mécanismes de mise en cache, optimiser les requêtes de base de données et utiliser des fonctions intégrées. 7

Expliquez la différence entre soi ::, parent :: et statique :: dans php oop. Expliquez la différence entre soi ::, parent :: et statique :: dans php oop. Apr 09, 2025 am 12:04 AM

Dans PhPoop, self :: fait référence à la classe actuelle, Parent :: fait référence à la classe parent, static :: est utilisé pour la liaison statique tardive. 1. self :: est utilisé pour la méthode statique et les appels constants, mais ne prend pas en charge la liaison statique tardive. 2.Parent :: est utilisé pour que les sous-classes appellent les méthodes de classe parent, et les méthodes privées ne sont pas accessibles. 3.Static :: prend en charge la liaison statique tardive, adaptée à l'héritage et au polymorphisme, mais peut affecter la lisibilité du code.

Comment PHP gère-t-il les téléchargements de fichiers en toute sécurité? Comment PHP gère-t-il les téléchargements de fichiers en toute sécurité? Apr 10, 2025 am 09:37 AM

PHP gère les téléchargements de fichiers via la variable de fichiers $ \ _. Les méthodes pour garantir la sécurité incluent: 1. Vérifiez les erreurs de téléchargement, 2. Vérifiez le type et la taille du fichier, 3. Empêchez l'écrasement des fichiers, 4. Déplacez les fichiers vers un emplacement de stockage permanent.

See all articles