Облачные функции для Firebase - Не удается загрузить URL: нет заголовка "Access-Control-Allow-Origin"

У меня есть приложение angular 2, где я вызываю Firebase через http-запрос. Однако в любое время я пытаюсь запустить функцию, я получаю эту ошибку:

XMLHttpRequest cannot load https://us-central1-<my-projectId>.cloudfunctions.net/[email protected] No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:4200' is therefore not allowed access. The response had HTTP status code 500.
    error_handler.js:54 EXCEPTION: Response with status: 0  for URL: null
    ErrorHandler.handleError @ error_handler.js:54
    next @ application_ref.js:348
    schedulerFn @ async.js:93
    SafeSubscriber.__tryOrUnsub @ Subscriber.js:234
    SafeSubscriber.next @ Subscriber.js:183
    Subscriber._next @ Subscriber.js:125
    Subscriber.next @ Subscriber.js:89
    Subject.next @ Subject.js:55
    EventEmitter.emit @ async.js:79
    NgZone.triggerError @ ng_zone.js:333
    onHandleError @ ng_zone.js:294
    ZoneDelegate.handleError @ zone.js:338
    Zone.runTask @ zone.js:169
    ZoneTask.invoke @ zone.js:420
    Subscriber.js:238 Uncaught Response {_body: ProgressEvent, status: 0, ok: false, statusText: "", headers: Headers…}

Вот моя облачная функция для файла Firebase index.js:

   const functions = require('firebase-functions');
    const admin = require('firebase-admin');
    admin.initializeApp(functions.config().firebase);
    const cors = require('cors')({origin: true});

    /**
     *  Function to get a user by email
     */
    exports.getUserByEmail = functions.https.onRequest((req, res) => {
      cors(request, response, () => {

// This should return a promise from the getUserByEmail function
response.status(200).send(admin.auth().getUserByEmail(req.query.email))
       })
    });

И вот здесь, как я вызываю функцию в компоненте (предполагая, что HTTP-запрос выполнен успешно):

this.http.get('https://us-central1-rosebud-9b0ed.cloudfunctions.net/getUserByEmail', {
       search: "[email protected]"
     }).subscribe(data => {
       console.log('data', data);
     })

Казалось бы, что бы я ни старался, я продолжаю сталкиваться с этой проблемой. Я даже попробовал развернуть это на моем размещенном в Firebase URL-адресе, и он все равно дает мне эту ошибку. Кто-нибудь знает, что я могу здесь сделать?

Спасибо заранее!

Ответ 1

Итак, я сделал несколько ключевых ошибок здесь.

  • Перед инициализацией приложения Firebase убедитесь, что требуется cors.
  • Убедитесь, что параметры выполняют функцию cors().

Вот обновленный index.js код:

  const functions = require('firebase-functions');
    const admin = require('firebase-admin');
    const cors = require('cors')({origin: true});
    admin.initializeApp(functions.config().firebase);


    /**
     *  Function to get a user by email
     */
    exports.getUserByEmail = functions.https.onRequest((request, response) => {
      cors(request, response, () => {

// This should return a promise from the getUserByEmail function
response.status(200).send(admin.auth().getUserByEmail(req.query.email))
       })
    });