Koa.js基础 认识Koa.js

先初始化和下载koa:

npm init -y
npm install koa -D

第一段代码:

const Koa = require("koa");	// 引入Koa

let server = new Koa();	// 创建实例
server.listen(8000);    // 监听端口

server.use(async ctx => {
    ctx.body = "hello, world!"
})
// ctx.body是给用户返回的内容

在这里插入图片描述
代码中的server没有直接的.get.post等方法,只有.use方法。
代码中的server.use中只接受一个参数,并且是函数。

中间件:

express和koa的核心概念,请求会顺序经过所有中间件处理(像流水线一样),得到最终结果。

  • 中间件按照添加的先后执行
  • ctx(上下文的对象)在整个执行过程中共享,非常适合传递数据
  • 需要手动调用next才会向下执行

ctx对象的第二个参数是next:

const Koa = require("koa");

let server = new Koa(); // 创建实例
server.listen(8000);    // 监听端口

server.use(async (ctx, next) => {
    ctx.body = "hello, world!";
    await next();
})
server.use(async ctx => {
    ctx.body += "hello, world! 2"
})
server.use(async ctx => {
    ctx.body = "hello, world! 3"
})

在这里插入图片描述
练习中间件:
读取文件返回给请求的客户端,并保存求情记录。

npm install promise-fs -D
const Koa = require("koa");
const fs = require("promise-fs")

let server = new Koa(); 
server.listen(8000); 

// 1.读取文件
server.use(async (ctx, next) => {
    let data = await fs.readFile('./data/1.txt');

    ctx.str = data.toString();
    await next();
})
// 2.保存日志
server.use(async (ctx, next) => {
    await fs.appendFile("access.log", `[${new Date().toGMTString()}] ${ctx.method} ${ctx.url} \n`);
    await next();
})
// 3.返回
server.use(async ctx => {
    ctx.body = ctx.str;
})

在这里插入图片描述
在这里插入图片描述
简化:

const Koa = require("koa");
const fs = require("promise-fs")

let server = new Koa(); // 创建实例
server.listen(8000);    // 监听端口


server.use(async (ctx, next) => {
    // 1.读取文件
    let data = await fs.readFile('./data/1.txt');
    // 2.保存日志
    await fs.appendFile("access.log", `[${new Date().toGMTString()}] ${ctx.method} ${ctx.url} \n`);
    // 3.返回
    ctx.body = data.toString();
})

中间件使用场景:

  • 全局性处理工作、权限、角色验证
  • 可重用组件
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值