2015-04-25 3 views
1

Я новичок в nodejs. Я пытаюсь создать HTTP-сервер, который использует инфраструктуру koa для обработки HTTP-запросов. Ниже приведен код для моего сервера.Тело запроса не определено для запроса POST в KOA

app.use(function * (next){ 
    var ctx = this; 

    var resource = url.parse(ctx.request.url, true, true).pathname; 
    switch(resource) { 
      case '/': 
        resource = config.app.root + '/dist/index.html'; 
        ctx.type = mime.lookup(resource); 
        ctx.body = fs.readFileSync(resource, 'utf-8'); 
        ctx.response.set('Access-Control-Allow-Origin', '*'); 
        break; 
      case '/fudge/contact': 
        console.log('============================'); 
        console.log(ctx.request); // no body 
        console.log('============================'); 
        console.log(ctx.req);  // no body 
        console.log('============================'); 
        console.log(ctx.request.body) // is undefined 
        break; 
      default: 
        resource = config.app.root + resource; 
        ctx.type = mime.lookup(resource); 
        ctx.body = fs.readFileSync(resource, 'utf-8'); 
        ctx.response.set('Access-Control-Allow-Origin', '*'); 
        break; 
    }}); 

Как упоминалось в случае '/ помадки/контакт' The ctx.request.body не определено. Но, когда я проверяю ctx.request или ctx.req, он показывает длину содержимого как 98 (или что-то ненулевое).

Ниже приводится вывод, который я получаю:

============================ 

{ 
method: 'POST', 
    url: '/fudge/contact', 
    header: 
    { host: 'localhost:9090', 
    'user-agent': 'Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:36.0) Gecko/20100101 Firefox/36.0', 
    accept: 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', 
    'accept-language': 'en-US,en;q=0.5', 
    'accept-encoding': 'gzip, deflate', 
    'content-type': 'text/plain; charset=UTF-8', 
    referer: 'http://localhost:9090/', 
    'content-length': '98', 
    connection: 'keep-alive', 
    pragma: 'no-cache', 
    'cache-control': 'no-cache'}} 
============================ 
{ _readableState: 
    { objectMode: false, 
    highWaterMark: 16384, 
    buffer: [], 
    length: 0, 
... more lines but no body. 
============================ 
undefined 

Ниже приводится код клиента: Я использовал HttpClient библиотеки рамок Aurelia.

 contactUs(){ 
      this.http.createRequest('/fudge/contact') 
        .asPost() 
        .withBaseUri('http://localhost:9090') 
        .withHeader('Content-Type','text/plain') 
        .withContent('{"heading":this.heading, "firstName":this.firstName, "lastName":this.lastName, "query":this.query}') 
        .send(); 
      alert(`Thank you, ${this.fullName}, your query has been successfully submitted`); 

    } 

Приведенный выше код javascript - ES7 и действителен, так как я использую транспилеры, такие как Babel. Точка в том, что я могу успешно отправить запрос POST на сервер, но в запросе нет тела. Пожалуйста, предложите некоторое решение.

Версии, используемая: Node v0.12.0, Коа v0.19.1

+1

с использованием ctx.request.on ('данные', функция (данные) { // некоторый код }); обработчик события i смог просмотреть тело запроса. Но будучи асинхронным, ответ отправлялся клиенту, прежде чем я смог обработать запрос. Поэтому я отправился на koa-тело, которое решило мою проблему. Я все еще хотел бы узнать точную проблему для лучшего понимания. Если кто-то может помочь. – havish

ответ

5

Коа не анализирующее тела запроса по умолчанию, вам нужно добавить промежуточное программное обеспечение для разбора тела, как koa-body, например:

var app  = require('koa')(), 
    router = require('koa-router'), 
    koaBody = require('koa-body')(); 

app.use(router()); 

app.post('/users', koaBody, 
    function *(next) { 
    console.log(this.request.body); 
    // => POST body 
    this.body = JSON.stringify(this.request.body); 
    } 
); 
app.listen(3131) 
console.log('curl -i http://localhost:3131/ -d "name=test"'); 

Философия Koa заключается в том, чтобы как можно меньше в основной каркас и позволить людям объединить свою систему, собрав специализированные средние. Из того, что я видел, существует несколько различных пакетов для разбора тела запроса, некоторые из них более простые, а другие имеют больше функций/опций (например, koa-better-body). Это все о предоставлении выбора разработчику без создания большого монолита.

Хотя этот подход может показаться странным, мне лично это нравится: он позволяет мне выбирать только те функции, которые мне нужны, без раздувания рамки с вариантами для каждого возможного варианта использования.

+0

Любые конкретные причины такого поведения? – havish

+0

Каково использование запроса без тела? Разборное тело должно быть встроенной функцией. Я жду ответа. – havish

+0

Отредактирован ответ, чтобы попытаться это разъяснить. Но на самом деле это просто другая структура с различными дизайнерскими решениями, чем то, что обычно можно ожидать. И это часть того, что делает его замечательным. –

Смежные вопросы