Node 8 + Typescript + Koa + koa-Router выдает TypeError: ctx.onerror не является функцией

У меня есть очень простой сервер, с которым можно поиграться:

import * as http from 'http';
import * as Koa from "koa";
import { Request, Response, Context } from "koa";
import * as Router from "koa-router";
import * as bodyParser from "koa-bodyparser";

const HTTPPORT = 3000;

var app:Koa = new Koa();
var router:Router = new Router();

app.use(async (ctx:Context, next)=> {
  console.log(ctx);
  return await next();
});

router.get('/', function (ctx) {
  ctx.body = "hello world";
  console.log("success")
});

app
  .use(bodyParser)
  .use(router.routes())
  .use(router.allowedMethods());

const  httpServer = http.createServer(app.callback());
//listen on provided port
httpServer.listen(HTTPPORT, () => {
  console.log(`${httpServer.address().address} (${httpServer.address().family}) is listening on port ${httpServer.address().port}`)
});

к сожалению, он все время выдает TypeError: ctx.onerror is not a function.

Следуя примерам на GitHub для koa-router (https://github.com/alexmingoia/koa-router), мой код должен работать нормально... Можете ли вы помочь мне разобраться, в чем проблема с этим сообщением onError?

при запуске сервера пишет следующее:

:: (IPv6) is listening on port 3000
{ request:
   { method: 'GET',
     url: '/',
     header:
      { host: 'localhost:3000',
        connection: 'keep-alive',
        'cache-control': 'max-age=0',
        'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36',
        'upgrade-insecure-requests': '1',
        accept: 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
        dnt: '1',
        'accept-encoding': 'gzip, deflate, br',
        'accept-language': 'en-US,en;q=0.9' } },
  response: { status: 404, message: 'Not Found', header: {} },
  app: { subdomainOffset: 2, proxy: false, env: 'development' },
  originalUrl: '/',
  req: '<original node req>',
  res: '<original node res>',
  socket: '<original node socket>' }
/.../node_modules/koa/lib/application.js:147
    const onerror = err => ctx.onerror(err);
                               ^

TypeError: ctx.onerror is not a function
    at Array.onerror (/.../node_modules/koa/lib/application.js:147:32)
    at listener (/.../node_modules/on-finished/index.js:169:15)
    at onFinish (/.../node_modules/on-finished/index.js:100:5)
    at callback (/.../node_modules/ee-first/index.js:55:10)
    at ServerResponse.onevent (/...s/node_modules/ee-first/index.js:93:5)
    at emitNone (events.js:111:20)
    at ServerResponse.emit (events.js:208:7)
    at onFinish (_http_outgoing.js:723:10)
    at _combinedTickCallback (internal/process/next_tick.js:131:7)
    at process._tickCallback (internal/process/next_tick.js:180:9)

Примечание Найдя решение, я загрузил рабочий код на gethub для всех желающих, пожалуйста, найдите его здесь: https://github.com/wzr1337/node.koa.webpack.starter


person wzr1337    schedule 11.01.2018    source источник


Ответы (1)


облом... это было bodyParser против bodyParser()

so

app
  .use(bodyParser())
  .use(router.routes())
  .use(router.allowedMethods());

отлично работают..

Спасибо @saadq за подсказку.. Я был слеп, чтобы увидеть, что мне не хватает ()...

person wzr1337    schedule 11.01.2018
comment
Первый способ должен подойти, но я уверен, что это должен быть app.use(bodyParser()) вместо app.use(bodyParser). - person Saad; 11.01.2018