读取文本文件 aws-amplify s3 从预先签名的 URL 读取数据

Bry*_*ump 2 amazon-s3 reactjs aws-amplify

如何使用 aws-amplify 库读取 s3 中的文本文件?我能够获取预先签名的 URL,但在访问该 url 时出现错误,

<Error>
<Code>NoSuchKey</Code>
<Message>The specified key does not exist.</Message>
<Key>
private/xx-xxxx-4:42134231243423142131423/filename.json
</Key>
<RequestId>1242341243</RequestId>
<HostId>
 uudawfeawefhszec/6kM8VawefawefawfawefawefgwegweawgeagweyRk=
</HostId>
</Error>
Run Code Online (Sandbox Code Playgroud)

文档有关于如何获取 url 的说明:

Storage.get('test.txt', {level: 'private'})
  .then(result => console.log(result))
  .catch(err => console.log(err));
Run Code Online (Sandbox Code Playgroud)

结果是路径的 url,而不是文本。当我运行 http get 方法时,端点不存在。

获取数据的最佳实践是什么?我正在使用反应。

如果有诸如 Storage.getText(...) 这样的方法,那将是最好的情况。

我试过使用这个添加授权......

  Auth.currentCredentials()
            .then(credentials => {
                axios.get(result, { headers: { 'Authorization': JSON.stringify(Auth.essentialCredentials(credentials)) } })
                    .then(r => {

                        console.log(r);
                    })
            });
Run Code Online (Sandbox Code Playgroud)

400 错误请求 :(

Bry*_*ump 6

查看源代码,S3Image 类在 Storage.get 方法中使用了一个未公开的参数

Storage.get('...', {download: true}) 
Run Code Online (Sandbox Code Playgroud)

是获取对象的正确方法。

该对象将需要被解码

    Storage.get('modules.json', { download: true })
        .then(result => {
            console.log(Utf8ArrayToStr(result.Body));
        })
        .catch(err => {
            console.log('error axios');
            console.log(err)
        });

function Utf8ArrayToStr(array) {
    var out, i, len, c;
    var char2, char3;

    out = "";
    len = array.length;
    i = 0;
    while (i < len) {
        c = array[i++];
        switch (c >> 4) {
            case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7:
                // 0xxxxxxx
                out += String.fromCharCode(c);
                break;
            case 12: case 13:
                // 110x xxxx   10xx xxxx
                char2 = array[i++];
                out += String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F));
                break;
            case 14:
                // 1110 xxxx  10xx xxxx  10xx xxxx
                char2 = array[i++];
                char3 = array[i++];
                out += String.fromCharCode(((c & 0x0F) << 12) |
                    ((char2 & 0x3F) << 6) |
                    ((char3 & 0x3F) << 0));
                break;
        }
    }

    return out;
}
Run Code Online (Sandbox Code Playgroud)

  • 建议的编辑:`console.log(result.Body.toString());` 你可以删除 `Utf8` 方法。然后,如果你得到一个 JSON 文件,只需执行 `console.log( JSON.parse( result.Body.toString() ) );` (2认同)