一次性搞定koa框架

前言


🐻大家好我是一溪风月程序员界的搬砖工,上篇文章我们学习和了解了Express框架,这个框架相对于直接使用HTTP模块而言,极大的提升了开发的效率和架构能力,接下来我们将会学习另外一个相对于Express框架而言更加轻量且强大的,被称为下一代node.js框架的koa框架,事实上koa框架和Express是同一个团队开发的一个新的框架,主要特点如下:

  1. 目前团队的核心开发者TJ的主要精力也在koa,express已经交给团队维护了。
  2. Koa旨在为Web应用程序和API提供更小、更丰富和更强大的能力。
  3. 相对于express具有更强的异步处理能力(后续我们再对比)
  4. Koa的核心代码只有1600+行,是一个更加轻量级的框架
  5. 我们可以根据需要安装和使用中间件;

一.koa初体验


🤡当我们学习了Express其实koa相对来讲就会比较简单,因为他们的核心是相同的就是中间件,首先我们使用koa来搭建一个服务然后创建一个接口。

js 复制代码
const koa = require('koa')

// 初始化koa
const app = new koa()

// 第一个中间件
app.use((ctx, next) => {
  console.log("第一个中间件")
  next()
})

// 第二个中间件
app.use((ctx, next) => {
  console.log("第二个中间件")
  //ctx.body = "Hello World!!!"
  ctx.response.body = "HelloWorld!!!"
})

app.listen(9000, () => {
  console.log("koa服务运行在9000端口")
})

然后我们试着使用apifox来请求下接口:

😎我们可以看到,koaExpress的区别在于中间件的参数不一样koa提供了两个参数,其中的一个参数是ctx,它被称为上下文对象。

  1. koa并没有像express一样,将req和res分开,而是将它们作为ctx的属性。
  2. ctx代表一次请求的上下文对象。
  3. ctx.request:获取请求对象(koa提供的,如果想用HTTP提供的使用ctx.req)。
  4. ctx.response:获取响应对象(koa提供的,如果想用HTTP提供的使用ctx.res);

🐻next本质上是一个dispatch和之前的功能基本相同。

二.koa中间件


🤡中间件可以说是koa的核心了,但是和Express不同的是,koa只能通过use来注册中间件,并且没有提供methods方式也没有提供path中间件来匹配路径,那么开发的时候我们怎么将路径和methods分离哪?我们主要有两种出来方式。

  1. 根据request自己进行判断(不推荐)
js 复制代码
const koa = require('koa')

// 初始化koa
const app = new koa()

app.use((ctx, next) => {
  if (ctx.request.path === '/user') {
    if (ctx.request.method === 'POST') {
      ctx.response.body = "创建用户成功"
    } else {
      ctx.response.body = "查询用户列表成功"
    }
  } else {
    ctx.response.body = "其他接口返回内容"
  }
})

app.listen(9000, () => {
  console.log("koa服务运行在9000端口")
})
  1. 使用第三方路由中间件(推荐):koa官方并没有给我们提供路由库,我们可以使用第三方库koa-router我们先进行安装一下npm install @koa/router
js 复制代码
const koa = require('koa')
const koaRouter = require('@koa/router')

// 初始化koa
const app = new koa()

const useRouter = new koaRouter({ prefix: '/user' })
useRouter.get('/', (ctx, next) => {
  ctx.body = "用户列表"
})

useRouter.post('/', (ctx, next) => {
  ctx.status = 201
  ctx.body = "用户创建"
})

app.use(useRouter.routes())
app.use(useRouter.allowedMethods())

app.listen(9000, () => {
  console.log("koa服务运行在9000端口")
})

三.koa参数解析


🥱解析参数parmasquery

js 复制代码
// localhost:9000/user/123
useRouter.get('/:id', (ctx, next) => {
  console.log(ctx.params.id)
  ctx.body = "HelloWorld"
})

查看下控制台结果,没有问题,直接在koa中就可以解析。

接下来我们进行query的解析。

js 复制代码
//localhost:9000/user/?name=1000&que=ttttt
useRouter.get('/', (ctx, next) => {
  console.log(ctx.request.query)
  ctx.body = "query查询"
})

我们使用如下这种方式进行请求然后看下结果。


🫥jsonx-www-form-urlencoded的参数解析:对这两个参数的解析koa里面不能直接进行解析,所以需要安装对应的第三方插件来解析

js 复制代码
npm install koa-bodyparser

然后我们将它注册为中间件app.use(bodyParser())然后就可以对上述的参数进行解析了

js 复制代码
const koa = require('koa')
const bodyParser = require('koa-bodyparser')

// 初始化koa
const app = new koa()

// 注册中间件
app.use(bodyParser())

app.use((ctx, next) => {
  console.log(ctx.request.body)
})


app.listen(9000, () => {
  console.log("koa服务运行在9000端口")
})

至于x-www-form-urlencoded的参数解析就不进行演示了,和json的一摸一样,可以自己尝试下。


🥱到此为止我们还有一个传参方式没有进行解析那就是form-data,这种方式的解析和上面两种也不一样,我们需要通过multer进行解析,这个我们也比较熟悉,需要注意的点是拿请求参数的是通过httpres来获取的。

js 复制代码
npm install koa-multer
js 复制代码
const koa = require('koa')
const multer = require('koa-multer')

// 初始化koa
const app = new koa()
const upload = multer({})
app.use(upload.any())
app.use((ctx, next) => {
  console.log(ctx.req.body)
  ctx.body = "Helloworld"
})



app.listen(9000, () => {
  console.log("koa服务运行在9000端口")
})

四.使用multer上传文件


😎文件上传的功能我们应该都不陌生了,在Express中我们已经通过multer成功的完成了这个功能,那么现在我们使用koa来进行实现一遍。

js 复制代码
const koa = require('koa')
const multer = require('koa-multer')
const Router = require('@koa/router')

const app = new koa()
// 文件上传
const useRouter = new Router()
const storage = multer.diskStorage({
  destination: function (req, file, cb) {
    cb(null, './uploads')
  },
  filename: function (req, file, cb) {
    cb(null, file.originalname)
  }
})

const upload = multer({ storage })
useRouter.post("/upload", upload.single('file'), (ctx, next) => {
  console.log(ctx.req.file)
  ctx.body = 'ok'
})
// 注册路由
app.use(useRouter.routes())
app.use(useRouter.allowedMethods())
app.listen(9000, () => {
  console.log("koa服务运行在9000端口")
})

发送请求,我们可以看到文件上传成功了。

五.静态文件服务器


🫥和Express一样,我们也可以使用koa来作为一个静态文件服务器,我们需要安装下第三方库:

arduino 复制代码
npm install koa-static

然后我们直接作为一个中间件使用以下这个下载的内容

js 复制代码
// 静态文件服务器
const koa = require('koa')

const app = new koa()

const static = require('koa-static')

app.use(static('./dist'))

app.listen(9001, () => {
  console.log("服务成功启动")
})

我们访问下这个端口,可以发现部署成功了,其实我们平时开发在本地起服务的时候底层也是这么做的,是不是发现了这些奇妙的关联~

六.数据的响应


🐻在koa中我们对数据的响应一般使用的是ctx.body或者ctx.reponse.body这两者其实是同样的东西,前者是后者的简写方式,我们使用哪个都可以,可以将响应结果设置为如下之一

  1. string:字符串数据
  2. Buffer:Buffer数据
  3. Stream:流数据
  4. Object|| Array:对象或者数组
  5. null :不输出任何内容
  6. 如果response.status尚未设置,Koa会自动将状态设置为200或204。
js 复制代码
ctx.response.body = "HelloWorld"

ctx.body = {
  name:"xxx",
  age:12,
  gender:'女'
}

ctx.body = ["a","b","c","d","e"]

响应状态的设置和上边使用方法一样。

ini 复制代码
ctx.status = 201
ctx.response.status = 200

七.koa错误处理


😂koa中的错误处理方式和Express中的不一样,在koa中进行错误的处理需要进行如下的操作

js 复制代码
const koa  = require("koa")
const app = new koa()
app.use((ctx,next)=>{
  ctx.app.emit('error',new Error("哈哈哈"),ctx)
})

app.on('error',(err,ctx)=>{
  console.log(err.message)
  ctx.response.body = "哈哈哈"
})

app.listen(8000,()=>{
  console.log("错误处理启动成功")
})

八.总结


😊在本章中我们学习了koa的基本使用及其错误处理,在下一节我们将详细介绍koa和Express的区别,以及洋葱模型相关的知识,相信随着我们一点点的学习我们会不断的进步,进而达到对自己的期待。

相关推荐
安的列斯凯奇2 小时前
SpringBoot篇 单元测试 理论篇
spring boot·后端·单元测试
架构文摘JGWZ3 小时前
FastJson很快,有什么用?
后端·学习
BinaryBardC3 小时前
Swift语言的网络编程
开发语言·后端·golang
邓熙榆3 小时前
Haskell语言的正则表达式
开发语言·后端·golang
专职6 小时前
spring boot中实现手动分页
java·spring boot·后端
Ciderw6 小时前
Go中的三种锁
开发语言·c++·后端·golang·互斥锁·
m0_748246357 小时前
SpringBoot返回文件让前端下载的几种方式
前端·spring boot·后端
m0_748230447 小时前
创建一个Spring Boot项目
java·spring boot·后端
卿着飞翔7 小时前
Java面试题2025-Mysql
java·spring boot·后端
C++小厨神7 小时前
C#语言的学习路线
开发语言·后端·golang