后端项目构建——Koa

本文介绍了Node.js的轻量级框架Koa,由Express团队开发,以其小体积和强大的表现力吸引开发者。Koa通过ES2015的async函数支持异步操作,简化了错误处理。文章通过创建一个简单的服务来展示Koa的易用性,并深入解释Koa的中间件机制,强调其逐层处理请求的特点,并通过示例展示了中间件的串联与错误处理。此外,还讨论了Koa如何优雅地处理异常情况,提供了统一的错误处理方式。
摘要由CSDN通过智能技术生成

1.为什么选择Koa

   Koa是由Express幕后原班人马打造的,相对于Express来说,Koa的体积更小,表现力更强,而且很干净,没有任何中间件等多余的插件,整体代码也就1000多行。而且提供了一整套优雅的方法,可以愉快而快速地编写服务端应用程序。

2.安装Koa

  Koa需要 node v7.6.0或更高版本来支持ES2015、异步方法,你可以安装自己支持的node版本。

使用 npm i koa 命令下载koa

  使用Koa开发很简单,不用像Express一样使用脚手架生成繁杂的文件夹和文件,仅用3行代码,即可构建一个Koa服务。在项目中新建一个app.js文件,并编写以下代码:

  编写这3行代码之后,在命令行工具中执行以下代码:

node app.js

  现在可以在本地的8889端口访问服务:

  看起来什么都没有,是因为没有给返回对象,Koa提供一个Context对象,简称ctx。表示一个HTTP的请求与回复,可以将返回的数据放在ctx.response.body中,这样前端就能接收到返回的数据,可以把app.js文件修改如下:

 

修改完成之后先运行一个app.js文件,在访问http://localhost:8889,即可得到Hello World的返回:

 

如此就完成了简单的Koa项目的构建,虽然功能很简单,但还是可以很明显地看出代码量相对于Express来说少了很多。

3.中间件

  Koa最大的特色就是中间件,它本身是没有任何中间件的,所有中间件都需要手动进行开发。用一个日志输出器来举例。

 

   Logger就是一个中间件,因为它在收到HTTP请求与返回HTTP请求之间,用来实现某种功能。之后使用app.use()来加载中间件。

  Koa中每个中间件都会有两个参数:一个是ctx;另一个是next。ctx就是本次请求和回复的主体对象,里面包含请求和返回的数据。next是执行下一步的函数,只要调用就会自动跳到下一个中间件。当只有一个中间件时,可能看不出next的作用;当有多个中间件时,就能看出next的作用。如:

 

这里定义并加载了3个中间件,分别为one、two、three。

结果如下:

 ---one

---two

为什么结果没有“---three”呢?仔细看代码,因为在two函数中没有使用next来传递执行权,所以,即使加载了three函数,在调用two函数的时候就结束传递了,因此根本就不会调用three函数。

4.异步函数

  Koa对异步函数的处理也很友好,无须使用promise来一层层包裹语句,使用async函数即可。

说明:main函数定义为一个异步函数,使用promise来模拟异步操作。首先在main函数加上async标识,之后在异步操作前加上await标识,如此main函数就会在await后面的语句执行完成之后才会进行下一步操作。相比于promise来说,更加容易使用,且不会陷入promise一层套一层的恐怖循环中去。

 5.处理报错信息

   一个程序运行时不可能不报错,Koa对报错的处理也十分简单,可以使用ctx.throw()方法直接抛出指定类型的错误,如404或500错误。对于更具体的报错,在每个中间件中,都可以使用try...catch来捕获错误,但这样操作未免有些麻烦,可以直接让最外层的中间件来捕获错误。

 在最外层的handler函数中监听了所有中间件的执行过程,若有报错,则会被catch之后判断报错类型,返回出去。try...catch语法结构也很简单,在try中执行需要执行的代码,如果代码出错,则会被下面的catch捕获到,然后执行catch中的语句。在main函数中使用ctx.throw()方法来报出500的错误,之后这个错误就会被handlerError函数捕获并且返回。

 

 

 

 

 

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值