什么是三层架构?

三层架构

三层架构来源于后端开发的一种分层的思想。

引用自百科的解释:

三层架构(3-tier architecture)通常意义上的三层架构就是将整个业务应用划分为:界面层(User Interface layer)、业务逻辑层(Business Logic Layer)、数据访问层(Data access layer)。

区分层次的目的即为了“高内聚低耦合”的思想。在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构。微软推荐的分层式结构一般分为三层,从下至上分别为:数据访问层、业务逻辑层(又或称为领域层)、表示层。

各层的作用如下:

  • 表示层:主要对用户的请求接受,以及数据的返回,为客户端提供应用程序的访问。
  • 业务逻辑层:主要负责对数据层的操作。也就是说把一些数据层的操作进行组合。
  • 数据访问层:主要看数据层里面有没有包含逻辑处理,实际上它的各个函数主要完成各个对数据文件的操作。而不必管其他操作。

具体的实现

如图:

在这里插入图片描述

首先在项目根目录下面创建 dao 和 service 目录。

  • dao:持久层
  • service:业务层
  • routes:表现层

在这里插入图片描述
接下来每一层的代码如下:

首先是 dao 层,这一层负责连接数据库等相关操作,所以会涉及到 连接数据库、创建 model 和 使用 model 操作数据库。

dao层:

// db.js
// 负责连接数据库

const mongoose = require('mongoose');
const dbURI = 'mongodb://localhost/f69'; // 配置要连接的数据库
mongoose.connect(dbURI,{useNewUrlParser : true,useUnifiedTopology: true});
mongoose.connection.on('connected',function(){
    console.log(`数据库已经连接成功,连接至${dbURI}`);
})
// stuModel.js
// 负责生成 model

require('../db');
const mongoose = require('mongoose');

// 定义 Schema,这是数据的骨架
const studentsSchema = new mongoose.Schema({
    name : String,
    gender : String,
    age : Number
},{versionKey: false})

// 生成 model
mongoose.model('studentsModel',studentsSchema,'students');
// 导出模型,之后,我们的增删改查操作都是基于这个 model 来执行的
module.exports = mongoose.model('studentsModel');
// stuDao.js
// 负责使用 model 来操作数据库

// 这个文件做具体的数据操作,增删改查
// 引入之前定义的 model,因为增删改查操作都是基于那个 model
const studentModel = require('./model/studentsModel');

// 新增
module.exports.addStudentDao = async function(stu){
    return await studentModel.create(stu);
}

在这里插入图片描述
service 层:
然后是 service 层,这一层主要负责业务逻辑处理,但是目前我们没有什么业务逻辑处理,所以只是单纯的调用持久层导出的方法。

// stuService.js

const { addStudentDao } = require('../dao/studentsDao')

module.exports.addStudentService = async function(stu){
    return await addStudentDao(stu);
}

在这里插入图片描述

router层:
然后是表现层,这一层负责接收前端传递过来的数据,然后传递给service

var express = require('express');
var router = express.Router();
const { addStudentService } = require('../service/studentsService');

/* GET home page. */
router.get('/', function(req, res, next) {
  res.render('index', { title: 'Express' });
  // res.send('hahah');
});

router.post('/addStu',async function(req,res){
  // 通过 req.body 拿到之后,接下来我们就想着将数据传递给下一层
  res.send(await addStudentService(req.body));
})

module.exports = router;

在这里插入图片描述

整个三层架构就搭建完毕了。

  • 30
    点赞
  • 140
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值