javascript - Firebase 函数返回 "Response is not valid JSON object."

标签 javascript firebase vue.js google-cloud-functions

我正在尝试从我的 vue 应用程序调用的 firebase 函数发送电子邮件。我的 firebase 函数如下所示:

const functions = require('firebase-functions');
const admin = require("firebase-admin")
const nodemailer = require('nodemailer');

admin.initializeApp()


//google account credentials used to send email
var transporter = nodemailer.createTransport({
    host: 'smtp.gmail.com',
    port: 465,
    secure: true,
    auth: {
        user: 'xxxxx@gmail.com',
        pass: 'xxxxxxxxxx'
    }
});


exports.sendMail = functions.https.onRequest((req, res) => {
    res.header("Access-Control-Allow-Origin", "*");
    res.header("Access-Control-Allow-Headers", "Content-Type");
    res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Authorization");
    const mailOptions = {
        from: `•••••••••@gmail.com`,
        to: req.body.email,
        subject: 'contact form message',
        html: `<h1>Order Confirmation</h1>
                            <p>
                               <b>Email: </b>"hello<br>
                            </p>`
    };


    return transporter.sendMail(mailOptions, (error, data) => {
        console.log("here")
        if (error) {
            return res.send({"data": error.toString()});
        }
        data = JSON.stringify(data)
        return res.send({"data": `Sent! ${data}`});
    });

});

我在这里删除了用户并传递值。它们在我的代码中具有正确的值。我用来调用此函数的 vue 方法如下所示:

sendEmail(){
        let sendMail = firebase.functions().httpsCallable('sendMail');
        sendMail(
            {
                email: 'xx@xx.xx.xx'
            }
        ).then(
            result => {
                console.log(result.data)
            }
        )
    }

调用此函数时,我在控制台中收到以下错误:

Uncaught (in promise) Error: Response is not valid JSON object.
at new e (index.cjs.js:58)
at t.<anonymous> (index.cjs.js:543)
at u (tslib.es6.js:100)
at Object.next (tslib.es6.js:81)
at s (tslib.es6.js:71)

如有任何帮助,我们将不胜感激。谢谢

最佳答案

以防万一这可以帮助任何人谷歌搜索这个问题,我得到了“响应不是有效的 JSON 对象”。错误,因为我没有在客户端中指定正确的区域,并且我的函数未托管在默认的美国区域中。我正在编写一个 react native Firebase 应用程序,因此我必须更改:

const result = await firebase.app().functions().httpsCallable("nameGoesHere");

致:

const result = await firebase.app().functions("europe-west1").httpsCallable("nameGoesHere");

关于javascript - Firebase 函数返回 "Response is not valid JSON object.",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61204210/

相关文章:

javascript - 无法在 firebase 函数中获取 setState

vue.js - 从 v-select 字段获取数据

javascript - 使用从 api 下载的数据在阵列上创建代理对象

javascript - 使用 React 单击时输入的值更新 URL

javascript - 无法在Firebase中捕获.on()的错误

ios - 当应用程序不在Appstore中时,Firebase动态链接无法在开发应用程序中打开

javascript - 如何覆盖 vue.js 中的全局变量?

javascript - 如何更改 Apexcharts RadialBar Charts 中非进度条的颜色?

javascript - 如何在xampp的子目录中运行react应用程序?

javascript - Angular:找不到 Promise、Map、Set 和 Iterator