后端架构分层——node.js

nodejs后端项目架构如何分层?

先说明下,本人是前端开发,文章的视角都是从前端工程师的视角出发,哈哈......

代码地址

源代码地址点击这里 文章只是写了大致思路,很多细节未说明,可以看看代码示例。

背景

从前端的认知来看,后端对我们前端来说就是提供了一个接口,我只需要请求这个接口,后端从这个接口返回给我对应的数据就好了,我不关心他做了哪些逻辑。

那现在假如要我开发一个后端项目,提供接口给前端使用,我需要做哪些工作呢?

使用nodejs

前端比较熟悉的能开发接口的工具就是nodejs了,那我们就创建一个nodejs项目吧。 nodejs无需安装,我们直接新建bin文件夹创建一个www.js文件,作为我们服务的入口文件。然后引入http开启服务

我们创建一个http服务,监听下request方法,即前端发来的所有请求都会触发这个方法。 然后在根目录创建一个app.js文件,提供一个serverHandle函数方法,所有的请求都由这个serverHandle函数来处理。

路由

当前端向我们的服务发起接口请求,例如:

所以后端收到请求后先要做这几个事情,

  • 判断是什么方法?
  • 请求的地址url是啥(要做什么事)?
  • 传了哪些参数给后端,怎么处理?

我们在serverHandle方法里来处理这几个事情,

可以看到,拿到请求后我们把请求的信息都拿到了,请求的方式(get/post),请求的地址(req.url),请求的参数(req.query/req.body)。 接下来我们要处理这些信息。

userRouterHandle

这里把数据初始化后直接调用了userRouterHanle方法,为什么要用这个方法?因为在用户信息这个模块中有很多功能接口要处理,注册、登录、查询...等等。我们把用户相关的所有请求都给userRouterHanle去处理,同理,其他模块也有各自的handle方法,比如商品信息我们可以自己封装goodsRouterHandle....

这个层级就叫Router层,专门用来处理解析前端传递的请求。

在router里对请求进行分类,来执行不同的逻辑。

Controller

我们对接口进行分类之后,就要走相关的处理逻辑了。

例如当前需要注册:我们的逻辑是:

  • 拿到用户的注册的用户名和密码,对用户输入的信息进行格式校验

  • 去数据库查询有没有已经存在的用户

  • 已经存在返回让前端重新注册,不存在就创建一个新用户

  • 返回数据的格式

  • .....其它逻辑处理

流程如下:

Service

业务逻辑处理完了,我们需要操作数据库了,还是拿注册来说,需要:

  • 查询是否存在
  • 存在,不让注册返回 / 不存在,在数据库新建用户

注册成功后需要登录:

  • 查询是否存在
  • 存在,检验后登录 / 不存在,返回信息

可以看到我们不同的逻辑对数据库有相同的操作,所以我们再次封装一下,把对数据库所有的操作都封装成一个Service层,里面提供的方法专门来操作数据库。

流程图变为:

总结

到此 我们后端架构的分层就很清晰了,大体上分为Router层、Controller层、和Srevice层。 接下来我们的业务就可以根据这个来开展了。。。

文中还没涉及静态文件处理以及数据格式封装、数据格式校验等等模块...

源码里有部分涉及,感兴趣的可以看看:源码地址

相关推荐
ADFVBM3 小时前
【Node.js]
node.js
摆烂式编程3 小时前
node.js 07.npm下包慢的问题与nrm的使用
前端·npm·node.js
东锋1.33 小时前
npm命令与yarn命令的区别
前端·npm·node.js
一纸忘忧9 小时前
Bun 1.2 版本重磅更新,带来全方位升级体验
前端·javascript·node.js
Amy_cx13 小时前
npm install安装缓慢或卡住不动
前端·npm·node.js
m0_748229991 天前
从零到上线:Node.js 项目的完整部署流程(包含 Docker 和 CICD)
docker·容器·node.js
yqcoder1 天前
node.js 文件操作
node.js
木偶☜1 天前
Node.js接收文件分片数据并进行合并处理
服务器·javascript·arcgis·node.js
梦魇梦狸º1 天前
node安装与管理
macos·node.js