无法加载默认凭据? (Node.js Google Compute Engine 教程)

情境:

我遵循这个教程: https://cloud.google.com/nodejs/tutorials/bookshelf-on-compute-engine

一切正常,直到我做 npm start,然后去:

Http://localhost:8080

我在空白页上看到以下文字:

Could not load the default credentials. Browse to https://developers.google.com/accounts/docs/application-default-credentials for more information.

因为我使用的是 OAuth,所以这没有意义。我跟随链接并阅读了页面,但是我没有任何 GOOGLE-APPLICATION-CREDENTIALS字段,在教程中也没有任何关于它的内容。


提问:

你能重复一下这些步骤并告诉我你是否得到了相同的结果吗?

(5分钟)

如果没有,我又能做错什么呢?

112060 次浏览

Yes, I had the same error. It's annoying cause Google Cloud Platform docs for their "getting started" bookshelf tutorial does not mention this anywhere. Which means that any new developer who tries this tutorial will see this error.

Read this: https://developers.google.com/identity/protocols/application-default-credentials

I fixed this issue by running: gcloud auth application-default login

In order to run thisgcloud auth application-default login Visit: https://cloud.google.com/sdk/install 1) You have to install sdk into your computer 2) That will enable you to run the code 3) Log in to your associated gmail account then you are good to go!

This will make you login, and after that you code locally will use that authentication.

If you're running the app locally, then the gcloud beta auth application-default login command should suffice for acquiring local credentials (I updated the tutorial to say so).

When running the app on Google Compute Engine, if the Compute Engine instance was created with the proper scopes (cloud-platform should be sufficient) then the app will authenticate with Google Cloud Platform APIs automatically without any extra work on your part.

There are 2 solutions for this problem. One option, as mentioned by others, is to use gcloud auth application-default login

Second option is to set the environment variable GOOGLE_APPLICATION_CREDENTIALS. It should point to a file that defines the credentials. To get this file you need to follow these steps:

Go to the API Console Credentials page.

From the project drop-down, select your project.

On the Credentials page, select the Create credentials drop-down, then select Service account key.

From the Service account drop-down, select an existing service account or create a new one.

For Key type, select the JSON key option, then select Create. The file automatically downloads to your computer.

Put the *.json file you just downloaded in a directory of your choosing.

This directory must be private (you can't let anyone get access to this), but accessible to your web server code.

Set the environment variable GOOGLE_APPLICATION_CREDENTIALS to the path of the JSON file downloaded.

See https://developers.google.com/identity/protocols/application-default-credentials for details

  1. Create a service account key using and download the json file. https://console.cloud.google.com/apis/credentials/serviceaccountkey

  2. Add this to your ENV file

    GOOGLE_APPLICATION_CREDENTIALS = "<PATH_TO_SERVICE_ACCOUNT_JSON_FILE>"

E.g:

GOOGLE_APPLICATION_CREDENTIALS=/Users/hello/Documents/ssh/my-10ebbbc8b3df.json

use this to solve your issue. this actually works:- just put credential parameter and give reference to your key to it.

const serviceAccount = require('../key.json');
admin.initializeApp({
credential: admin.credential.cert(serviceAccount)
});

Go here: https://firebase.google.com/docs/admin/setup#initialize_the_sdk and follow the instructions to create a private key. Then after you have downloaded your private key open command prompt in the project directory and do the following command:

 set GOOGLE_APPLICATION_CREDENTIALS=C:\YOUR-PATH\YOUR-KEY.json

I got this error because of initially I did like below:

var admin = require("firebase-admin");
admin.initializeApp(); // I didnt add anything because firebaserc file include appName

It worked when I deployed the functions but not in serve. So this is how I solved it:

  • Go to the firebase Project settings(click on setting icon from side nav).
  • Click on the Service accounts.
  • Copy the admin sdk configuration snippet from selecting your pro. lang.

Ex (node.js):

var admin = require("firebase-admin");


var serviceAccount = require("path/to/serviceAccountKey.json");


admin.initializeApp({
credential: admin.credential.cert(serviceAccount),
databaseURL: "https://your-domain.firebaseio.com"
});
  • Now we need to add serviceAccountKey.json file.
  • Click on the Manage service account permissions in top right corner.
  • Now, you will see services accounts for your project, in the table find the row with column name name and value firebase-adminsdk, in that row click on Action dots and select Create key.
  • From the pop up dialog select Key type as json and press create button.
  • You will prompt to download the file, download it to your functions directory in project(You can customize this as you want and if you pushing to github, make sure to ignore that file).
  • Now, if you save it into the same directory where you are initializeApp(), access that file like: ./socialape-15456-68dfdc857c55.json(In my case, both files are located: functions/index.js and functions/services.son in functions directory and in index.js file, I initialed my firebase admin sdk).

Ex(node.js):

const functions = require('firebase-functions');


var admin = require("firebase-admin");


var serviceAccount = require("./myapp-15456-68dfdc857c55.json");


admin.initializeApp({
credential: admin.credential.cert(serviceAccount),
databaseURL: "https://myapp-15456.firebaseio.com"
});

It's a best and good idea to create .env file and include your file there and access it as others mentioned. I leave that part to you.

Hope this help someone on the planet. Regards!

I also had this error problem, here I had not created the object of

keyFilename (stores the credentials of the api)

in the sessionClient object for nodejs app.

const sessionClient = new dialogflow.SessionsClient({
keyFilename: "./keyCredentials.json"
});
        

const sessionPath = sessionClient.sessionPath(projectId, sessionId);

To download 'keyCredentials.json' goto:

https://console.cloud.google.com/apis/credentials/serviceaccountkey

Also add the path of this file to the system variables

  1. In windows open powershell
  2. type GOOGLE_APPLICATION_CREDENTIALS = [PATH_TO_SERVICE_ACCOUNT_JSON_FILE]

Although this question has been answered multiple times, I found myself in a situation not explained here.

After I created the variable: $GOOGLE_APPLICATION_CREDENTIALS, I was getting the same error as Coder1000.

However, I was running both: nodemon and: npm run dev in two separate sessions in Terminal, neither of which were aware of the variable.

Once I: shut the tabs down; added new tabs; and ran the commands again, the application was able to access the variable.

For all people using firebase, what it worked for me was passing the credentials to the KeyManagementServiceClient constructor

const serviceAccount = require('../keys/file.json'); //<- your firebase credentials
const client = new KeyManagementServiceClient({
credentials: serviceAccount,
});

Another solution i found: in your package.json add an export command like this:

"scripts": {
"start": "export GOOGLE_APPLICATION_CREDENTIALS='./gcloud.json' && node ./bin/www --exec babel-node --presets babel-preset-env",
},

You have to create an object of your SessionsClient. Here I will provide some steps, so you can run your code like a charm.

  1. You have to go into your Dialogflow dashboard.
  2. Click on setting ( Left navbar top-right gear icon)
  3. in the General tab click Service Account link ( it will redirect you to another screen)
  4. If you have a service account then ignore step 5
  5. Create a service account ( Top-center +icon button)
    • Now you have a service account on a list click on
  6. From the action, field presses the 3 vertical dots and create a key.
  7. Download the JSON file on your local computer.
  8. Assign object to your sessionClient.
const sessionClient = new dialogflow.SessionsClient({
keyFilename: "/var/www/html/moqatrips/dialog-flow.json"
});

you may find youself in another part of the world -- and land here. I'm adding to a three year old question because its keywords matched my issue and the preceding answers helped me although none describe my issue

firebase deploy --only functions --debug

produced

[2020-12-02T08:31:50.397Z] FirebaseError: HTTP Error: 429, Unknown Error
Error: Could not read source directory. Remove links and shortcuts and try again.

I could not find anything wrong with the source directory. But that was all so many tiny fish.

Examining the error in detail, from the top, lead to:

Our systems have detected unusual traffic from your computer network.  This page checks to see if it&#39;s really you sending the requests, and not a robot.
The block will expire shortly after those requests stop.

Out of curiosity and exhaustion, I waited first. The wait reset duration is > than 30 minutes. So i pursued the captcha to prove my enduring humanity which did register eventually after some oauth warnings.

If anyone ran into the issue just like me and doesn't want to set the variable each time before running their code it's best to manually set the environment variable. Name it GOOGLE_APPLICATION_CREDENTIALS and browse the downloaded JSON file. If you don't know the steps follow this: https://docs.oracle.com/en/database/oracle/machine-learning/oml4r/1.5.1/oread/creating-and-modifying-environment-variables-on-windows.html#GUID-DD6F9982-60D5-48F6-8270-A27EC53807D0

I was facing the same issue. It got fixed with following command.

gcloud auth application-default login

It stores default gcloud cloud credentials on your system and uses the same.