我试图从 firebase/gc 存储中的文件中获取signedurl。我能找到的所有其他解决方案是创建一个服务帐户,下载服务密钥,然后在我的应用程序中使用它,但我这样做了,但仍然收到错误。我也遵循了这个建议,并使用 Firebase getSignedUrl() 将相关角色添加到我的服务帐户 SigningError中。
client_email 属性位于我使用的服务密钥中。
对于服务帐户和 gc 来说相当新,所以我可能会错过一些简单的东西。
我能够列出存储桶,并且对 cloud firestore 的所有其他请求都在工作。事实证明,它只是特定文件的签名 URL 很难检索。
让我有点疯狂,所以任何帮助都会很棒。
这是我的代码。
const functions = require('firebase-functions');
const admin = require('firebase-admin');
const express = require('express');
const { ApolloServer, gql } = require('apollo-server-express');
const { Storage } = require('@google-cloud/storage');
const serviceAccount = require('./emom-84ee4-firebase-adminsdk-2309z-aab93226ec.json');
const keyfileName = require('./emom-84ee4-ac9e94667d5e.json');
admin.initializeApp({
credential: admin.credential.cert(serviceAccount),
databaseURL: "https://emom-84ee4.firebaseio.com"
});
const storage = new Storage({
projectId: 'emom-84ee4',
keyFileName: keyfileName,
// TRIED THIS ALSO => keyFileName: serviceAccount
});
const typeDefs …Run Code Online (Sandbox Code Playgroud) javascript node.js google-cloud-storage firebase google-cloud-firestore
我有两种方法:
validateRegistration(),它调用 app.get('/users/:email', todo)
login(),它调用 app.get('/users/:username', todo)
validateRegistration() 工作正常,但是当 login() 被调用时,它返回 null,但是如果我在 server.js 中注释掉 app.get('/users/:email', todo),login() 返回预期的响应. 似乎两者不能同时存在于 server.js
请参阅下面的相关代码
注册页面.html
<div class="container" ng-show="show">
<form name="registerForm" novalidate>
<h2>Registration</h2>
<span>All fields required</span>
<br>
<br>
<label>First Name</label>
<br>
<input class="form-control" type="text" ng-model="user.fName" name="fName" required placeholder="First Name">
<div ng-messages="registerForm.fName.$error">
<div class="errorMsg" ng-message="required">Required</div>
</div>
<br>
<label>Last Name</label>
<input class="form-control" type="text" ng-model="user.lName" name="lName" required placeholder="Last Name">
<div ng-messages="registerForm.lName.$error">
<div class="errorMsg" ng-message="required">Required</div>
</div>
<br>
<label>Email</label>
<input class="form-control" ng-model="user.email" ng-change="validateEmail(user.email)" type="email" name="emailAdd" required placeholder="Email">
<span class="errorMsg">{{emailExistsMsg}}</span>
<div …Run Code Online (Sandbox Code Playgroud)