


How to correctly divide business logic and non-business logic in hierarchical architecture in back-end development?
Apr 19, 2025 pm 07:15 PMBack-end hierarchical architecture: cleverly divide business logic and non-business logic
In back-end development, a layered architecture (for example, Controller, Service, and DAO layers) is crucial. Although the hierarchy principle is clear, in practice, especially the boundaries between the Service layer and the DAO layer, as well as the logical division after the introduction of the Manager layer, are often confusing. This article will explore how to effectively distinguish between business logic and non-business logic.
Definition between business logic and non-business logic
Business logic directly relates to business needs, which users can perceive; while non-business logic is an underlying operation and has nothing to do with business processes, such as database operation details or password encryption.
Here are some examples of non-business logic:
-
Database operation details:
UserManager.delete()
andDepartmentManager.delete()
may delete data in association tables (such asuserdeptmodel
) at the same time. This is non-business logic because it only involves database operations, not business processes themselves. Without the Manager layer, the DAO layer can also handle such operations, as long as it has nothing to do with the business.class UserManager: def delete(self): userdao.delete() userdeptdao.delete() class DepartmentManager: def delete(self): departmentdao.delete() userdeptdao.delete()
-
Password encryption: Users do not need to know the details of password storage, and the salt operation can be placed in the DAO or Manager layer.
class UserDao: def make_password(self, passwd): return salt(passwd) # Assume that the salt function is used to add salt to the password def save(self): passwd = self.make_password(passwd) self.passwd = passwd super().save() #Suppose super().save() is a database save method
DAO layer method naming: Whether a method name like
get_super_user
is suitable depends on whether it involves business logic. Ifsuper
is not business-related, it can be used; otherwise, it should be handled at the Service layer.HTTP request encapsulation: The backend-dependent encapsulation can be placed in the DAO layer instead of the Service layer.
Implement functions similar to Django filter in Python
In Django/Flask, data filtering is relatively easy. However, in Python's three-layer architecture, it is necessary to consider how to process request parameters in the DAO layer. If there is no dependency injection framework like Spring, the parameters need to be passed manually. In Java, ORM frameworks such as Hibernate provide powerful data filtering and query functions.
Data Entities and Hierarchical Architecture
Data entities are used for data persistence. In a three-layer architecture, the Controller, Service and DAO layers do not strictly correspond to one by one. The Service layer may call multiple DAOs to complete a business operation, and a DAO may also be called by multiple Services.
In short, correctly distinguishing business logic from non-business logic is the key to back-end development, and a reasonable hierarchical architecture can improve code readability and maintainability.
The above is the detailed content of How to correctly divide business logic and non-business logic in hierarchical architecture in back-end development?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The key to dealing with API authentication is to understand and use the authentication method correctly. 1. APIKey is the simplest authentication method, usually placed in the request header or URL parameters; 2. BasicAuth uses username and password for Base64 encoding transmission, which is suitable for internal systems; 3. OAuth2 needs to obtain the token first through client_id and client_secret, and then bring the BearerToken in the request header; 4. In order to deal with the token expiration, the token management class can be encapsulated and automatically refreshed the token; in short, selecting the appropriate method according to the document and safely storing the key information is the key.

How to efficiently handle large JSON files in Python? 1. Use the ijson library to stream and avoid memory overflow through item-by-item parsing; 2. If it is in JSONLines format, you can read it line by line and process it with json.loads(); 3. Or split the large file into small pieces and then process it separately. These methods effectively solve the memory limitation problem and are suitable for different scenarios.

In Python, the method of traversing tuples with for loops includes directly iterating over elements, getting indexes and elements at the same time, and processing nested tuples. 1. Use the for loop directly to access each element in sequence without managing the index; 2. Use enumerate() to get the index and value at the same time. The default index is 0, and the start parameter can also be specified; 3. Nested tuples can be unpacked in the loop, but it is necessary to ensure that the subtuple structure is consistent, otherwise an unpacking error will be raised; in addition, the tuple is immutable and the content cannot be modified in the loop. Unwanted values can be ignored by \_. It is recommended to check whether the tuple is empty before traversing to avoid errors.

Python implements asynchronous API calls with async/await with aiohttp. Use async to define coroutine functions and execute them through asyncio.run driver, for example: asyncdeffetch_data(): awaitasyncio.sleep(1); initiate asynchronous HTTP requests through aiohttp, and use asyncwith to create ClientSession and await response result; use asyncio.gather to package the task list; precautions include: avoiding blocking operations, not mixing synchronization code, and Jupyter needs to handle event loops specially. Master eventl

Pure functions in Python refer to functions that always return the same output with no side effects given the same input. Its characteristics include: 1. Determinism, that is, the same input always produces the same output; 2. No side effects, that is, no external variables, no input data, and no interaction with the outside world. For example, defadd(a,b):returna b is a pure function because no matter how many times add(2,3) is called, it always returns 5 without changing other content in the program. In contrast, functions that modify global variables or change input parameters are non-pure functions. The advantages of pure functions are: easier to test, more suitable for concurrent execution, cache results to improve performance, and can be well matched with functional programming tools such as map() and filter().

ifelse is the infrastructure used in Python for conditional judgment, and different code blocks are executed through the authenticity of the condition. It supports the use of elif to add branches when multi-condition judgment, and indentation is the syntax key; if num=15, the program outputs "this number is greater than 10"; if the assignment logic is required, ternary operators such as status="adult"ifage>=18else"minor" can be used. 1. Ifelse selects the execution path according to the true or false conditions; 2. Elif can add multiple condition branches; 3. Indentation determines the code's ownership, errors will lead to exceptions; 4. The ternary operator is suitable for simple assignment scenarios.

The falsy values ??in Python include: empty string ''; numbers 0 and 0.0; empty list []; empty dictionary {}; empty tuple(); boolean value False; special value None. Almost all other values ??except these values ??are truthy, such as non-zero numbers, non-empty strings, non-empty data structures, and default custom objects. In actual development, you need to pay attention to: ifxisnotNone should be used to check whether it is None; when processing function returns a value, you need to judge in combination with business logic; you can use the truthy/falsy feature to simplify conditional expressions, but be careful to avoid misunderstandings or errors. Understanding the concepts of truthy and falsy helps to write more reliable and concise conditional judgment codes.

In Python, although there is no built-in final keyword, it can simulate unsurpassable methods through name rewriting, runtime exceptions, decorators, etc. 1. Use double underscore prefix to trigger name rewriting, making it difficult for subclasses to overwrite methods; 2. judge the caller type in the method and throw an exception to prevent subclass redefinition; 3. Use a custom decorator to mark the method as final, and check it in combination with metaclass or class decorator; 4. The behavior can be encapsulated as property attributes to reduce the possibility of being modified. These methods provide varying degrees of protection, but none of them completely restrict the coverage behavior.
