Modèle de conception de référentiel démystifié
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" } },
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 ); }
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 ) { // 查询数据源并获取糖果详情 } }
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' );
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" } },
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!

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

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

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

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

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.

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.
