Превышен суточный лимит на Неаутентифицированное использование. Для продолжения использования требуется ошибка регистрации

Я пытаюсь загрузить файл с google диска с помощью node.js. Это моя первая попытка использовать Google SDK, поэтому я просто следовал инструкциям и скопировал код из образцов. Я могу успешно получить метаданные из файлов, присутствующих в моем gdrive , но всякий раз, когда я пытаюсь загрузить файл, это вызывает ошибку. Пожалуйста, найдите впереди фрагмент кода, который я использую ниже, который не что иное, как примеры, приведенные в документации.

            var fs = require('fs');
            var readline = require('readline');
            var google = require('googleapis');
            var googleAuth = require('google-auth-library');
            var request = require("request");

            // If modifying these scopes, delete your previously saved credentials
            // at ~/.credentials/drive-nodejs-quickstart.json
            //var SCOPES = ['https://www.googleapis.com/auth/drive.metadata.readonly'];
            var SCOPES = ['https://www.googleapis.com/auth/drive'];
            /* var TOKEN_DIR = (process.env.HOME || process.env.HOMEPATH ||
                process.env.USERPROFILE) + '/.credentials/'; */
            var TOKEN_DIR = process.env.USERPROFILE + '/.credentials/'; 
            var TOKEN_PATH = TOKEN_DIR + 'drive-nodejs-quickstart.json';

            // Load client secrets from a local file.
            fs.readFile('client_secret.json', function processClientSecrets(err, content) {
              if (err) {
                console.log('Error loading client secret file: ' + err);
                return;
              }
              // Authorize a client with the loaded credentials, then call the
              // Drive API.
              authorize(JSON.parse(content), listFiles);
            });

            /**
             * Create an OAuth2 client with the given credentials, and then execute the
             * given callback function.
             *
             * @param {Object} credentials The authorization client credentials.
             * @param {function} callback The callback to call with the authorized client.
             */
            function authorize(credentials, callback) {
              var clientSecret = credentials.installed.client_secret;
              var clientId = credentials.installed.client_id;
              var redirectUrl = credentials.installed.redirect_uris[0];
              var auth = new googleAuth();
              var oauth2Client = new auth.OAuth2(clientId, clientSecret, redirectUrl);

              // Check if we have previously stored a token.
              fs.readFile(TOKEN_PATH, function(err, token) {
                if (err) {
                  getNewToken(oauth2Client, callback);
                } else {
                  oauth2Client.credentials = JSON.parse(token);
                  callback(oauth2Client);
                }
              });
            }

            /**
             * Get and store new token after prompting for user authorization, and then
             * execute the given callback with the authorized OAuth2 client.
             *
             * @param {google.auth.OAuth2} oauth2Client The OAuth2 client to get token for.
             * @param {getEventsCallback} callback The callback to call with the authorized
             *     client.
             */
            function getNewToken(oauth2Client, callback) {
              var authUrl = oauth2Client.generateAuthUrl({
                access_type: 'offline',
                scope: SCOPES
              });
              console.log('Authorize this app by visiting this url: ', authUrl);
              var rl = readline.createInterface({
                input: process.stdin,
                output: process.stdout
              });
              rl.question('Enter the code from that page here: ', function(code) {
                rl.close();
                oauth2Client.getToken(code, function(err, token) {
                  if (err) {
                    console.log('Error while trying to retrieve access token', err);
                    return;
                  }
                  oauth2Client.credentials = token;
                  storeToken(token);
                  callback(oauth2Client);
                });
              });
            }

            /**
             * Store token to disk be used in later program executions.
             *
             * @param {Object} token The token to store to disk.
             */
            function storeToken(token) {
              try {
                fs.mkdirSync(TOKEN_DIR);
              } catch (err) {
                if (err.code != 'EEXIST') {
                  throw err;
                }
              }
              fs.writeFile(TOKEN_PATH, JSON.stringify(token));
              console.log('Token stored to ' + TOKEN_PATH);
            }

            /**
             * Lists the names and IDs of up to 10 files.
             *
             * @param {google.auth.OAuth2} auth An authorized OAuth2 client.
             */
            function listFiles(auth) {
              var service = google.drive('v3');
              service.files.list({
                auth: auth,
                pageSize: 10,
                fields: "nextPageToken, files(id, name)"
              }, function(err, response) {
                if (err) {
                  console.log('The API returned an error: ' + err);
                  return;
                }
                var files = response.files;
                if (files.length == 0) {
                  console.log('No files found.');
                } else {
                  for (var i = 0; i < files.length; i++) {
                    var file = files[i];
                    if(file.name.indexOf('Expense') > -1) {
                        downloadFile(file.id);
                    }


                  }
                }
              });
            }

            /**
             * Download a file's content.
             *
             * @param {File} file Drive File instance.
             * @param {Function} callback Function to call when the request is complete.
             */


            function downloadFile(fileId) {
            //file['exportLinks']['application/pdf'];

              //var fileId = '0BwwA4oUTeiV1UVNwOHItT0xfa2M';
                    var service = google.drive('v3');
                    var dest = fs.createWriteStream('/test.doc');
                    service.files.get({
                       fileId: fileId,
                       alt: 'media'
                    })
                    .on('end', function() {
                      console.log('Done');
                    })
                    .on('error', function(err) {
                      console.log('Error during download', err);
                    })
                    .pipe(dest);

            }

Я только попробовал 17-20 запросов за последний час и не думаю, что я использовал все свои квоты. Я проверил, что GDrive api включен в моем проекте. Пожалуйста помочь.

1 ответ

  1. Исходя из этой документации , ошибка 403 означает, что вы достигли максимальной скорости запросов Google Drive API. Лимит варьируется в зависимости от типа запросов. Предлагаемое действие состоит в пакетной обработке запросов . Попробуйте уменьшить количество HTTP-подключений, которые должен сделать клиент.

    Другой обходной путь-проверить состояние Google + API в консоли разработчика. Он должен быть установлен на ON. Подождите несколько минут после включения и убедитесь, что вы получили новый маркер.

    Проверьте эти связанные SO вопросы: