@ loopback / rest RestBindings.Http.request возвращает пустую переменную запроса - PullRequest
0 голосов
/ 28 ноября 2018

Я работал с ранними версиями пакета Loopback v4 в течение достаточно долгого времени, и привязка RestBindings.Http.Request работала хорошо до одного из самых последних обновлений (не совсем уверен, когда это произошло).

Я все еще могу получить значения для большинства свойств, но не для свойства запроса.Даже в самом простом проекте, использующем контроллер ping по умолчанию, свойство запроса остается пустым.Ниже приведен пример моего кода, моего запроса и ответа:

import { Request, RestBindings, get, ResponseObject } from '@loopback/rest';
import { inject } from '@loopback/context';

export class PingController {
  constructor(@inject(RestBindings.Http.REQUEST) private req: Request) { }

  // Map to `GET /ping`
  @get('/ping')
  ping(): object {
    // Reply with a greeting, the current time, the url, and request headers
    return {
      query: 'Query response: ' + this.req.query.start,
      greeting: 'Hello from LoopBack',
      date: new Date(),
      url: this.req.url,
      headers: Object.assign({}, this.req.headers),
    };
  }
}

Запрос: localhost: 3000 / ping? Start = 2018-08-25 & end = 2018-09-09 & user = larsm

Выход:

    {   
   "query": "Query response: undefined",   
   "greeting": "Hello from LoopBack",   
   "date": "2018-11-27T23:21:53.142Z",   
   "url": "/ping?start=2018-08-25&end=2018-09-09&user=larsm",   
   "headers": {
        "host": "localhost:3000",
        "connection": "keep-alive",
        "cache-control": "max-age=0",
        "upgrade-insecure-requests": "1",
        "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.102 Safari/537.36",
        "accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8",
        "accept-encoding": "gzip, deflate, br",
        "accept-language": "nb-NO,nb;q=0.9,en-GB;q=0.8,en;q=0.7,no;q=0.6,nn;q=0.5,en-US;q=0.4"   } }

Ответы [ 2 ]

0 голосов
/ 06 декабря 2018

Эта проблема будет исправлена ​​в следующем выпуске, см. https://github.com/strongloop/loopback-next/pull/2089

0 голосов
/ 02 декабря 2018

Итак, я выяснил, что вышеуказанные проблемы вызваны преднамеренным изменением в библиотеке @ loopback / rest, то есть обработкой только тех параметров запроса, которые предварительно определены.

Это означает, что вам нужно определить их конкретно в вашем контроллере, например, как в следующем простом примере:

  @get('/larsm')
  greet(
    @param.query.string('start') start: string,
    @param.query.string('end') end: string,
    @param.query.string('name') name: string,
  ) {
    return 'start: ' + start + ', end: ' + end + ', name: ' + name;
  }
}

Поскольку существует несколько вариантов использования, где это не всегда идеально, я поднял вопрос проблема с командой Loopback, и похоже, что они решили отменить самое последнее изменение.

...