koa-router 使用教程

本系列是我的常用 koa 中间件使用笔记,防止忘记使用方法而作记录

Koa-router 是 koa 的一个路由中间件,它可以将请求的URL和方法(如:GETPOSTPUTDELETE 等) 匹配到对应的响应程序或页面。可以把路由分发到各个文件里,起到分层的作用。

 

基本配置

下面的代码创建了一个 koa 的http 服务,引入user.js文件并且使用,并且监听3000端口。

//app.js

const Koa = require('koa'); // 引入koa
const app = new Koa(); // 创建koa应用

const user = require('./user');     //引入suer
app.use(user.routes(),user.allowedMethods());

app.listen(3000);

这是 user.js 文件。 

//user.js

const Router = require('koa-router')

const router = new Router({ //设置前缀
    prefix: '/user'
});

router.get('/string', async (ctx, next) => {
    ctx.body = 'user'
})

module.exports = router

 

不同请求方式

Koa-router 请求方式: getputpostpatchdeletedel ,而使用方法就是 router.方式() ,比如 router.get()router.post() 。而 router.all() 会匹配所有的请求方法。

当匹配成功就会执行中间件运行。

//匹配到get请求,在/string下
router.get('/string', async (ctx, next) => {
    ctx.body = 'user'
})

 

设置前缀

在实例化 Router 的时候可以设置前缀,之后匹配的请求都会自动添加这个前缀。

下面的链接 localhost:3000/user/string

const router = new Router({ //设置前缀
    prefix: '/user'
});

//我的链接 localhost:3000/user/string
router.get('/string', async (ctx, next) => {
    ctx.body = 'user'
})

 

.allowedMethods()用途

如果使用 post 请求访问 user 路由,默认会返回 not find 状态码404,因为没有匹配到。使用了 allowedMethods 会返回 Method Not Allowed 状态码 405。

并且如果访问 option 请求会默认返回1 状态码200

const Koa = require('koa'); // 引入koa
const app = new Koa(); // 创建koa应用

const user = require('./user');     //引入suer
app.use(user.routes(),user.allowedMethods());

throw 设置为 true 便会触发 methodNotAllowed 这个回调函数

app.use(user.allowedMethods({
    throw: true, //抛出错误,代替设置响应头状态
    methodNotAllowed: () => {  //不匹配方法执行的回调函数
        console.log('没有匹配到');
    }
}))

 


 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值