8

我正在尝试使用 loadFromPath 加载 AWS 的凭证并收到意外错误。使用 AWS.config.update 对相同的凭证进行硬编码可以正常工作。为了确保凭据文件的路径和格式正确,我使用 fs.readFile 加载了相同的文件,并且加载正确,因此似乎没有任何路径/权限问题。这似乎超级基本,但我一直在努力解决问题。谢谢你的帮助。

错误/输出:

    Here: /home/ec2-user/.ec2/credentials.json
    Got this through readFile: { access_id: 'XXXXXXX',
    private_key: 'XXXXXXX',
    keypair: 'praneethkey',
    'key-pair-file': '/home/ec2-user/.ec2/praneethkey.pem',
    region: 'us-west-2' }

    /home/ec2-user/node_modules/aws-sdk/lib/config.js:221
    if (err) throw err;
                   ^
  SyntaxError: Unexpected token <
    at Object.parse (native)
    at /home/ec2-user/node_modules/aws-sdk/lib/metadata_service.js:100:38
    at IncomingMessage.<anonymous> (/home/ec2-user/node_modules/aws-sdk/lib/metadata_service.js:75:43)
    at IncomingMessage.EventEmitter.emit (events.js:117:20)
    at _stream_readable.js:910:16
    at process._tickCallback (node.js:415:13)

编码:

'use strict';

var AWS = require('aws-sdk');
var fs = require('fs');

var pathv = process.env.HOME + '/.ec2/credentials.json';

AWS.config.loadFromPath(pathv);

console.log('Here: ' + pathv);


fs.readFile(pathv, 'utf8', function (err, data) {
  if (err) {
    console.log('Error: ' + err);
    return;
  }
  data = JSON.parse(data);

console.log("Got this through readFile:",data);
4

2 回答 2

11

您可以跳过凭证配置,如果您有环境变量
AWS_ACCESS_KEY_ID 和 AWS_SECRET_ACCESS_KEY
AWS SDK 将默认读取这些变量

如果您仍想从文件中加载凭据,请检查 credentials.json 是否具有有效的 JSON。

关于http://aws.amazon.com/sdkfornodejs/ 应该类似于

{ "accessKeyId": "akid", "secretAccessKey": "secret", "region": "us-west-2" }

好像你有 access_id 应该是“accessKeyId”,而 private_key 应该是“secretAccessKey”

于 2013-08-09T07:40:42.080 回答
2

找到了这个问题的答案。出于某种奇怪的原因,亚马逊在 Node 和其他框架(例如 Ruby)中使用不同的字段名称作为凭证。

在 Ruby 中,只有前两项是:

"access_id": "[Your AWS Access Key ID]",
"private_key": "[Your AWS Secret Access Key]",

在 Node.js 中,这些相同的项目是:

"accessKeyId": "[Your AWS Access Key ID]",
"secretAccessKey": "[Your AWS Secret Access Key]",

将凭证 JSON 中的名称更改为后者,错误消失了。为什么不能一样?

于 2013-08-09T08:16:46.827 回答