我可以将邮递员用于在Firebase中作为函数的onCall方法吗?

Mik*_*sen 5 firebase postman google-cloud-functions

因此,我做了这个非常简单的方法,我想使用自定义令牌登录到Firebase。截至目前,它只是

export const createCustomToken = functions.region('europe-west1').https.onCall(async (data, context) => {

    try {
        const firebaseJWT = await authenticationProvider.createCustomToken()
        console.log(firebaseJWT.toString())
    } catch (err) {
        throw new functions.https.HttpsError('internal', 'Something went wrong ');
    }
});
Run Code Online (Sandbox Code Playgroud)

authenticationProvider看起来像这样:

return firebase.admin.auth().createCustomToken("Some uid")
       .then((token) => {
           console.log("Did create custom token.");
           return token;
       }).catch((error) => {
           console.log("Error creating custom token:" + error);
           throw new firebase.functions.https.HttpsError('internal', 'createCustomToken(uid) has failed for some reason');
       }) 
}
Run Code Online (Sandbox Code Playgroud)

我尝试使用shell方法在本地运行它,在命令提示符下执行以下行:firebase functions:shell,然后调用authenticationController.createCustomToken({})

这只是给我以下响应:创建自定义令牌时出错:错误:无法确定服务帐户。确保使用服务帐户凭据初始化SDK。或者,指定一个具有iam.serviceAccounts.signBlob权限的服务帐户。原始错误:错误:发出请求时出错:getaddrinfo ENOTFOUND元数据元数据:80。错误代码:ENOTFOUND

服务帐户似乎具有适当的角色,所以我认为这不是问题。

因此,我想知道是否可以通过某种方式从邮递员那里叫我createCustomToken()函数,并查看响应,以便我可以正确地测试代码,而无需应用程序实现onCall方法来查看结果?

还是我缺少通过firebase functions:shell命令运行它的功能?

MAZ*_*MAZ 8

您可以按照此处的官方文档中所述使用请求标头在Postman上测试firebase函数

首先,您必须在项目的根文件夹中使用以下命令在本地提供功能

firebase serve
Run Code Online (Sandbox Code Playgroud)

您也可以在此处查看官方文档如何在本地提供服务

在运行以上命令时,您将获得函数的http链接。像这样

http://localhost:5000/{YOUR_FIREBASE_PROJECT_NAME}/us-central1/myFunction
Run Code Online (Sandbox Code Playgroud)

将该链接用于Postman中的POST请求。在Postman的“正文”部分中,从下拉列表中选择“原始”,然后选择“ JSON(application / json)”,然后在正文部分中键入以下正文示例

{
    "data": {}
}
Run Code Online (Sandbox Code Playgroud)

添加在身体的“数据”的说法这个JSON对象,如文档中提到的,需要在这里。检查以下屏幕截图以供参考

屏幕截图显示了示例主体,用于请求Postman中的onCall方法

现在,您可以发送请求以获取功能的响应。希望能帮助到你 :)

  • 我得到这个“该函数必须在经过身份验证时调用。” 错误 (4认同)
  • @phongyewtong 这对我有用——你是否添加了 { "data": {} } 作为 JSON 主体?当我不传递空数据对象时,我收到该错误 (3认同)
  • 对我不起作用。“消息”:“错误请求”,“状态”:“INVALID_ARGUMENT” (2认同)
  • 我在选项卡“header”中添加了“content-type”=“application/json”,然后它也对我有用 (2认同)
  • 确保您发送的是 POST,而不是 GET (2认同)