后端架构分层——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层。 接下来我们的业务就可以根据这个来开展了。。。

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

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

相关推荐
我叫黑大帅3 小时前
Sequelize:让你和数据库唠嗑像聊微信一样简单 😎
后端·node.js
小山不高6 小时前
本地使用minio之前后端关键点
前端·node.js
吓死羊了6 小时前
设置nginx和tomcat开机自动启动
后端·node.js·tomcat
归于尽6 小时前
浏览器和 Node.js 的 EventLoop,原来差别这么大
前端·node.js·浏览器
前端双越老师7 小时前
30 行代码 langChain.js 开发你的第一个 Agent
人工智能·node.js·agent
浪裡遊17 小时前
React Hooks全面解析:从基础到高级的实用指南
开发语言·前端·javascript·react.js·node.js·ecmascript·php
whale fall18 小时前
npm install安装的node_modules是什么
前端·npm·node.js
会飞的鱼先生18 小时前
Node.js-http模块
网络协议·http·node.js
用户35218024547521 小时前
MCP极简入门:node+idea运行简单的MCP服务和MCP客户端
node.js·ai编程
觅_1 天前
Node.js 的线程模型
node.js