


Comment faire la distinction entre la logique métier et la logique non commerciale dans le développement back-end et effectuer une conception en couches raisonnable?
Apr 19, 2025 pm 08:45 PMArchitecture hiérarchique arrière: limites claires entre la logique métier et la logique non commerciale
Dans le développement back-end, les architectures courantes à trois niveaux de Controller, Service et DAO ne sont pas toujours assez claires. Cet article explique comment distinguer efficacement la logique métier et la logique non commerciale dans les couches de service et de DAO, et même après avoir introduit la couche de gestionnaire, afin de créer une conception en couches plus raisonnable.
Définition entre la logique métier et la logique non commerciale
La logique métier relie directement les exigences de l'entreprise, bien que la logique des affaires ne soit pas responsable des opérations sous-jacentes, telles que l'accès aux données, la vérification des données, etc. Les frontières floues entre les deux conduisent souvent à la confusion dans le code.
-
Encapsulation des opérations de données: par exemple,
UserManager.delete()
etDepartmentManager.delete()
peuvent gérer la suppression associée deUserDeptModel
en même temps. Il s'agit d'une logique non commerciale car elle se concentre sur la cohérence des données plut?t que sur le processus métier lui-même. Exemple de code:classe Usermanager: def delete (self, user_id): self.user_dao.delete (user_id) self.user_dept_dao.delete_by_user_id (user_id) Département de département de classe: def delete (self, Dept_id): self.dept_dao.delete (Dept_id) self.user_dept_dao.delete_by_dept_id (Dept_id)
-
Traitement de la sécurité des données: le salage de mot de passe et d'autres opérations sont généralement effectués sur DAO ou la couche Manager, car il s'agit d'un mécanisme de protection des données, et non de la logique métier. Exemple de code (Python avec une fonction
salt
hypothétique):Classe UserDao: Def Save (self, utilisateur): user.password = self.salt (user.password) # ... Enregistrer l'utilisateur dans la base de données ... Def Salt (soi, mot de passe): # ... Logique de salting de mot de passe ... retourner Salted_password
Méthode DAO Méthode de dénomination Spécification: les noms de méthode de couche DAO doivent éviter d'inclure des significations commerciales. Par exemple,
get_super_user()
n'est pas aussi clair queget_user_by_type("super")
.Encapsulation des appels de service externe: si le backend dépend des services externes, ces appels doivent être encapsulés sur la couche DAO, pas la couche de service, car il s'agit d'accès aux données, pas de logique métier.
Simuler la fonction de filtre Django
Dans Python, s'il n'y a pas de cadre d'injection de dépendance, la moquerie du filtre Django nécessite du traitement des paramètres de la demande au niveau de la couche DAO et de leur passage de couche par couche. Le framework Spring de Java simplifie ce processus.
Entité de données et relation de hiérarchie
Le contr?leur, le service et le DAO ne correspondent pas un par un. Leurs responsabilités sont les suivantes:
- Contr?leur: Entrée du système, réception et demandes de traitement, en le gardant léger.
- Service: la couche de traitement de la logique métier principale est relativement complexe.
- DAO: La couche d'accès aux données n'est responsable que de l'interaction des données et n'inclut pas la logique métier.
Par exemple, "Créer un utilisateur": la couche de service effectue "Vérifiez si le nom d'utilisateur est dupliqué" et "Créer un utilisateur"; La couche DAO fournit des "utilisateurs de requête en fonction du nom d'utilisateur" et des méthodes "Enregistrer les utilisateurs".
En distinguant clairement la logique commerciale de la logique non commerciale et en suivant une conception en couches raisonnable, la maintenabilité et l'évolutivité du code peuvent être améliorées.
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

Le polymorphisme est un concept de base dans la programmation orientée objet Python, se référant à "une interface, plusieurs implémentations", permettant le traitement unifié de différents types d'objets. 1. Le polymorphisme est implémenté par la réécriture de la méthode. Les sous-classes peuvent redéfinir les méthodes de classe parent. Par exemple, la méthode Spoke () de classe animale a des implémentations différentes dans les sous-classes de chiens et de chats. 2. Les utilisations pratiques du polymorphisme comprennent la simplification de la structure du code et l'amélioration de l'évolutivité, tels que l'appel de la méthode Draw () uniformément dans le programme de dessin graphique, ou la gestion du comportement commun des différents personnages dans le développement de jeux. 3. Le polymorphisme de l'implémentation de Python doit satisfaire: la classe parent définit une méthode, et la classe enfant remplace la méthode, mais ne nécessite pas l'héritage de la même classe parent. Tant que l'objet implémente la même méthode, c'est ce qu'on appelle le "type de canard". 4. Les choses à noter incluent la maintenance

Les itérateurs sont des objets qui implémentent __iter __ () et __Next __ (). Le générateur est une version simplifiée des itérateurs, qui implémentent automatiquement ces méthodes via le mot clé de rendement. 1. L'ITERATOR renvoie un élément chaque fois qu'il appelle Next () et lance une exception d'arrêt lorsqu'il n'y a plus d'éléments. 2. Le générateur utilise la définition de la fonction pour générer des données à la demande, enregistrer la mémoire et prendre en charge les séquences infinies. 3. Utilisez des itérateurs lors du traitement des ensembles existants, utilisez un générateur lors de la génération de Big Data ou de l'évaluation paresseuse, telles que le chargement ligne par ligne lors de la lecture de fichiers volumineux. Remarque: les objets itérables tels que les listes ne sont pas des itérateurs. Ils doivent être recréés après que l'itérateur a atteint sa fin, et le générateur ne peut le traverser qu'une seule fois.

Une méthode courante pour parcourir deux listes simultanément dans Python consiste à utiliser la fonction zip (), qui appariera plusieurs listes dans l'ordre et sera la plus courte; Si la longueur de liste est incohérente, vous pouvez utiliser itertools.zip_langest () pour être le plus long et remplir les valeurs manquantes; Combiné avec enumerate (), vous pouvez obtenir l'index en même temps. 1.zip () est concis et pratique, adapté à l'itération des données appariées; 2.zip_langest () peut remplir la valeur par défaut lorsqu'il s'agit de longueurs incohérentes; 3. L'énumération (zip ()) peut obtenir des indices pendant la traversée, en répondant aux besoins d'une variété de scénarios complexes.

Assert est un outil d'affirmation utilisé dans Python pour le débogage et lance une affirmation d'établissement lorsque la condition n'est pas remplie. Sa syntaxe est affirmer la condition plus les informations d'erreur facultatives, qui conviennent à la vérification de la logique interne telle que la vérification des paramètres, la confirmation d'état, etc., mais ne peuvent pas être utilisées pour la sécurité ou la vérification des entrées des utilisateurs, et doit être utilisée en conjonction avec des informations d'invite claires. Il n'est disponible que pour le débogage auxiliaire au stade de développement plut?t que pour remplacer la manipulation des exceptions.

Pour faire d'un objet un générateur, vous devez générer des valeurs à la demande en définissant une fonction contenant un rendement, en implémentant des classes itérables qui implémentent \ _ \ _ iter \ _ et \ _next \ _ méthodes, ou à l'aide d'expressions de générateur. 1. Définissez une fonction contenant le rendement, renvoyez l'objet générateur lorsqu'il est appelé et générez des valeurs successivement; 2. Implémentez le \ _ \ _ iter \ _ \ _ et \ _ \ _ Next \ _ \ _ \ _ dans une classe personnalisée pour contr?ler la logique itérative; 3. Utilisez des expressions de générateur pour créer rapidement un générateur léger, adapté aux transformations simples ou au filtrage. Ces méthodes évitent de charger toutes les données dans la mémoire, améliorant ainsi l'efficacité de la mémoire.

TypeHintsInpythonsolvetheproblebandofambigu?té et opposant à un montant de type de type parallèlement au développement de l'aménagement en fonction des types de type.

Inpython, itérateurslawjectsThatallowloopingthroughCollectionsbyImpleting __iter __ () et__Next __ (). 1) iteratorsworkVeatheitorat

Pour appeler le code Python en C, vous devez d'abord initialiser l'interprète, puis vous pouvez réaliser l'interaction en exécutant des cha?nes, des fichiers ou en appelant des fonctions spécifiques. 1. Initialisez l'interpréteur avec py_initialize () et fermez-le avec py_finalalize (); 2. Exécuter le code de cha?ne ou pyrun_simplefile avec pyrun_simplefile; 3. Importez des modules via pyimport_importmodule, obtenez la fonction via pyObject_getattrstring, construisez des paramètres de py_buildvalue, appelez la fonction et le retour de processus
