zoukankan      html  css  js  c++  java
  • koa-router

    为了处理URL,我们需要引入koa-router这个middleware,让它负责处理URL映射。

    我们把上一节的hello-koa工程复制一份,重命名为url-koa

    先在package.json中添加依赖项:

    "koa-router": "7.0.0"
    

    然后用npm install安装。

    或者在项目中使用 npm i koa-router

    接下来,我们修改app.js,使用koa-router来处理URL:

    const Koa = require('koa');
    
    // 注意require('koa-router')返回的是函数:
    const router = require('koa-router')();
    
    const app = new Koa();
    
    // log request URL:
    app.use(async (ctx, next) => {
        console.log(`Process ${ctx.request.method} ${ctx.request.url}...`);
        await next();
    });
    
    // add url-route:
    router.get('/hello/:name', async (ctx, next) => {
        var name = ctx.params.name;
        ctx.response.body = `<h1>Hello, ${name}!</h1>`;
    });
    
    router.get('/', async (ctx, next) => {
        ctx.response.body = '<h1>Index</h1>';
    });
    
    // add router middleware:
    app.use(router.routes());
    
    app.listen(3000);
    console.log('app started at port 3000...');

    注意导入koa-router的语句最后的()是函数调用:

    const router = require('koa-router')();
    

    相当于:

    const fn_router = require('koa-router');
    const router = fn_router();
    

    然后,我们使用router.get('/path', async fn)来注册一个GET请求。可以在请求路径中使用带变量的/hello/:name,变量可以通过ctx.params.name访问。

    再运行app.js,我们就可以测试不同的URL:

    输入首页:http://localhost:3000/

    url-index

    输入:http://localhost:3000/hello/koa

    url-hello

  • 相关阅读:
    二叉搜索树
    【树】List Leaves
    模板——dijkstra单源最短路
    余数求和——除法分块
    倍增——ST表
    线段树——内存池
    线段树——模板
    洛谷 P1498 南蛮图腾
    洛谷 P2199 最后的迷宫
    洛谷 P1495 中国剩余定理
  • 原文地址:https://www.cnblogs.com/cangqinglang/p/10238173.html
Copyright © 2011-2022 走看看