我有一个名为sendMail
的firebase
函数,用于发送电子邮件。我正在尝试将收件人的电子邮件地址和另一个参数传递给函数。在我的vue
应用程序中,我调用函数如下:
sendEmail(){
console.log(this.email)
let sendMail = firebase.functions().httpsCallable('sendMail');
sendMail(
{
"email": this.email,
"superu": this.superu
}
).then(
result => {
console.log(result)
}
)
}
我的函数index.js
看起来像:
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: '*****@****.com',
pass: '***********'
}
});
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");
console.log(req.body['data']);
const mailOptions = {
from: `•••••••••@gmail.com`,
to: req.body['data'].email,
subject: 'contact form message',
html: `<h2 style="color: teal">Order Confirmation</h2>
<a href="https://track-acquintances.firebaseapp.com/signup/${req.body.superu}">
<b> Register </b>"<br>
</a>`
};
return transporter.sendMail(mailOptions, (error, data) => {
if (error) {
return res.status(200).json({data: error.message});
}
data = JSON.stringify(data)
return res.status(200).json({data: data});
});
});
问题是我无法访问传递的电子邮件数据,功能失败。我将req.body['data']
记录到功能日志中,然后看到{ email: 'xxx@xx.xxx.x', superu: true }
。但我同时尝试了req.body['data'].email
和req.body['data']['email']
,但它们都不起作用。在浏览器控制台中,我得到了{data: "No recipients defined"}
。如有任何帮助,我们将不胜感激。谢谢
您混淆了两种类型的云函数:
-
您的云功能被定义为HTTPS触发的功能,这意味着您可以通过在浏览器中访问其URL、调用
fetch
或使用XMLHTTPRequest
来调用它。 -
您的客户端代码尝试调用一个所谓的可调用云函数,这是一种不同的类型。虽然可调用云函数也可以通过HTTPS直接调用,但它们有一个特定的有线协议可供调用。
由于这两种类型的函数不匹配,因此客户端代码传递参数的格式与服务器处理的格式不同。
您需要调用HTTPS函数,或者将Cloud函数转换为可调用。后者看起来像:
exports.sendMail = functions.https.onCall((data, context) => {
const email = data.email;
const superu = data.superu;
...
});