0

0

后端开发中的分层架构如何正确划分业务逻辑和非业务逻辑?

聖光之護

聖光之護

发布时间:2025-03-23 08:14:19

|

715人浏览过

|

来源于php中文网

原创

后端开发中的分层架构如何正确划分业务逻辑和非业务逻辑?

后端分层架构:巧妙划分业务逻辑与非业务逻辑

后端开发中,分层架构(例如,Controller、Service、DAO三层)至关重要。虽然分层原则清晰,但在实践中,特别是Service层和DAO层间的界限,以及引入Manager层后的逻辑划分,常常令人困惑。本文将探讨如何有效区分业务逻辑和非业务逻辑。

业务逻辑与非业务逻辑的界定

业务逻辑直接关联业务需求,用户可感知;而非业务逻辑则为底层操作,与业务流程无关,例如数据库操作细节或密码加密。

以下是一些非业务逻辑示例:

  1. 数据库操作细节: UserManager.delete()DepartmentManager.delete() 可能同时删除关联表(例如userdeptmodel)中的数据。这属于非业务逻辑,因为它只涉及数据库操作,而非业务流程本身。如果没有Manager层,DAO层也可以处理这类操作,只要它与业务无关。

     class UserManager:
         def delete(self):
             userdao.delete()
             userdeptdao.delete()
    
     class DepartmentManager:
         def delete(self):
             departmentdao.delete()
             userdeptdao.delete()
  2. 密码加密: 用户无需了解密码存储细节,加盐操作可放在DAO或Manager层。

     class UserDao:
         def make_password(self, passwd):
             return salt(passwd)  # 假设salt函数用于密码加盐
    
         def save(self):
             passwd = self.make_password(passwd)
             self.passwd = passwd
             super().save() #假设super().save()是数据库保存方法
  3. DAO层方法命名: get_super_user 这样的方法名是否合适,取决于其是否涉及业务逻辑。如果super与业务无关,则可以使用;否则,应在Service层处理。

    FastGPT
    FastGPT

    FastGPT 是一个基于 LLM 大语言模型的知识库问答系统

    下载
  4. HTTP请求封装: 后端依赖的封装,可以放在DAO层,而非Service层。

Python中实现类似Django filter的功能

在Django/Flask中,数据过滤相对容易。但在Python的三层架构中,需要考虑如何在DAO层处理请求参数。如果没有Spring之类的依赖注入框架,则需手动传递参数。 Java中,Hibernate等ORM框架提供了强大的数据过滤和查询功能。

数据实体与分层架构

数据实体用于数据持久化。在三层架构中,Controller、Service和DAO层并非严格一一对应。Service层可能调用多个DAO完成一个业务操作,而一个DAO也可能被多个Service调用。

总之,正确区分业务逻辑和非业务逻辑是后端开发的关键,合理的分层架构能提升代码可读性和可维护性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

112

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

27

2026.01.26

Python Flask框架
Python Flask框架

本专题专注于 Python 轻量级 Web 框架 Flask 的学习与实战,内容涵盖路由与视图、模板渲染、表单处理、数据库集成、用户认证以及RESTful API 开发。通过博客系统、任务管理工具与微服务接口等项目实战,帮助学员掌握 Flask 在快速构建小型到中型 Web 应用中的核心技能。

86

2025.08.25

Python Flask Web框架与API开发
Python Flask Web框架与API开发

本专题系统介绍 Python Flask Web框架的基础与进阶应用,包括Flask路由、请求与响应、模板渲染、表单处理、安全性加固、数据库集成(SQLAlchemy)、以及使用Flask构建 RESTful API 服务。通过多个实战项目,帮助学习者掌握使用 Flask 开发高效、可扩展的 Web 应用与 API。

72

2025.12.15

hibernate和mybatis有哪些区别
hibernate和mybatis有哪些区别

hibernate和mybatis的区别:1、实现方式;2、性能;3、对象管理的对比;4、缓存机制。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

142

2024.02.23

Hibernate框架介绍
Hibernate框架介绍

本专题整合了hibernate框架相关内容,阅读专题下面的文章了解更多详细内容。

84

2025.08.06

Java Hibernate框架
Java Hibernate框架

本专题聚焦 Java 主流 ORM 框架 Hibernate 的学习与应用,系统讲解对象关系映射、实体类与表映射、HQL 查询、事务管理、缓存机制与性能优化。通过电商平台、企业管理系统和博客项目等实战案例,帮助学员掌握 Hibernate 在持久层开发中的核心技能。

35

2025.09.02

Hibernate框架搭建
Hibernate框架搭建

本专题整合了Hibernate框架用法,阅读专题下面的文章了解更多详细内容。

64

2025.10.14

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.3万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号