koa-router中nested router(嵌套路由)的坑

刚刚开始学习Koa框架不久,在使用koa-router路由中间件的时候遇到一个坑,浪费了点时间,必须要做个记录,给后人一个提醒!

koa-router简单使用方式如下:

app.js

 

const koa = require('koa');
const router = require('koa-router')();
const http = require('http');
const app = koa();
router.get('/',function* (){
	//do something!
})
app.use(indexRouter.routes(),indexRouter.allowedMethods());
http.createServer(app.callback()).listen(3000,function(){'the server is listening on port 3000'})
 

 

考虑后期开发路由的增多,于是把所有路由规则放在另一个文件里,再在app.js里导入

新增routes/index.js

 

const router = require('koa-router')();
router.get('/',function*(){
	console.log("the request path is '/' ");
	//do something else!
});
router.get('/ha',function*(){
	console.log('path is /ha');
});
module.exports = router;

 

app.js修改如下:

 

const koa = require('koa');
const router = require('koa-router')();
const http = require('http');
const indexRouter = require('./routes/index');
const app = koa();

router.use('/',indexRouter.routes(),indexRouter.allowedMethods());

app.use(indexRouter.routes(),indexRouter.allowedMethods());
http.createServer(app.callback()).listen(3000,function(){'the server is listening on port 3000'})

 

 

浏览器访问如下路径:

 

 

http://127.0.0.1:3000/  -----可以正常访问

http://127.0.0.1:3000/ha -----无法访问

 

阅读koa-router文档发现有Nested Router(嵌套路由)这一说,其原理就是将多个路径合并起来,而我代码里写的路由配置,转换过来的话,其实路由是这样的:

http://127.0.0.1:3000/

http://127.0.0.1:3000//ha ----这种肯定无法访问

 

 

将index.js文件 router.get('/ha')路径修改成router.get('ha')即可。路由显示为

http://127.0.0.1:3000/ha

并且可以正常访问地址

 

刚接触koa不久,本文有误之处,还请提出,感谢!

 

 

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
本文档介绍了koa-router的使用方法和API,帮助开发者更好地应用koa-router进行路由管理。 koa-router是一个基于koa路由管理器,它提供了一种简单、灵活的方式来定义和处理路由。它支持常见的RESTful API风格,如GET、POST、PUT和DELETE等,同时还支持间件和参数传递等特性。 安装koa-router 在使用koa-router之前,我们需要先安装它。可以通过npm进行安装: ``` npm install koa-router ``` 使用koa-router 在使用koa-router之前,我们需要先引入它: ```javascript const Koa = require('koa'); const Router = require('koa-router'); const app = new Koa(); const router = new Router(); ``` 定义路由koa-router,我们可以通过router对象来定义路由。以下是一个简单的例子: ```javascript router.get('/', async (ctx, next) => { ctx.body = 'Hello World!'; }); router.get('/users', async (ctx, next) => { ctx.body = 'User List!'; }); router.get('/users/:id', async (ctx, next) => { const { id } = ctx.params; ctx.body = `User ${id}`; }); ``` 上面的例子,我们定义了三个路由: - GET /: 返回"Hello World!" - GET /users: 返回"User List!" - GET /users/:id: 返回"User {id}",其:id表示一个参数 使用路由 在定义完路由后,我们需要将它们应用到Koa应用程序: ```javascript app.use(router.routes()); app.use(router.allowedMethods()); ``` 其,`router.routes()`用于将路由应用到应用程序,`router.allowedMethods()`用于处理不支持的HTTP方法。 间件 koa-router还支持间件,可以通过以下方式使用: ```javascript const auth = async (ctx, next) => { if (ctx.isAuthenticated()) { await next(); } else { ctx.status = 401; ctx.body = 'Unauthorized'; } }; router.get('/private', auth, async (ctx, next) => { ctx.body = 'Private Content!'; }); ``` 上面的例子,我们定义了一个间件`auth`,它用于验证用户是否已经通过身份验证。在定义路由时,我们将其作为第二个参数传递给`router.get()`方法,表示只有通过身份验证的用户才能访问该路由。 参数传递 koa-router还支持参数传递,可以通过以下方式使用: ```javascript router.get('/users/:id', async (ctx, next) => { const { id } = ctx.params; const user = await getUserById(id); ctx.body = user; }); ``` 上面的例子,我们使用`:id`作为参数占位符,并通过`ctx.params`获取传递的参数值。 API koa-router的API如下: - router.get(path, middleware): 定义一个GET路由 - router.post(path, middleware): 定义一个POST路由 - router.put(path, middleware): 定义一个PUT路由 - router.delete(path, middleware): 定义一个DELETE路由 - router.patch(path, middleware): 定义一个PATCH路由 - router.head(path, middleware): 定义一个HEAD路由 - router.options(path, middleware): 定义一个OPTIONS路由 - router.all(path, middleware): 定义一个支持所有HTTP方法的路由 - router.use(middleware): 定义一个间件 - router.routes(): 返回应用程序定义的路由 - router.allowedMethods(): 处理不支持的HTTP方法 总结 koa-router是一个灵活、易用的路由管理器,它提供了丰富的特性,如RESTful API风格、间件、参数传递等。通过学习本文档,开发者可以更好地了解koa-router的使用方法和API,从而更好地应用koa-router进行路由管理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值