2

我成功生成了访问令牌,但现在我无法使用它。遗憾的是,没有用于使用 API 的官方 yandex 节点库。有 2 个非官方的 npm 模块只能与服务器一起使用,但我希望它是 localhost。作为这样的代码示例,在这种情况下,我想显示磁盘中的所有文件。当然,我为我的应用启用了所有范围

request.get('https://cloud-api.yandex.net/v1/disk/resources/files/', {
  'auth': {
    'bearer': 'xxxxxxxxxxxxxxxxxxx'
  }
}, function(err,httpResponse,body){ /* ... */ 
if(err) {
console.log('err: ' + err)
}
console.log('body: ' + body)
});

另外,如果我会使用https://cloud-api.yandex.net/v1/disk/resources/files?oauth_token=xxxxxxxxxxxxxx&oauth_client_id=xxxxxxxxxxxxxxxxxxx
https://cloud-api.yandex.net/v1/disk/resources/files ?access_token=xxxxxxxxxxxxxx&client_id=xxxxxxxxxxxxxxxxxxx
在我的浏览器中我会得到
{"message":"?? ???????????.","description":"Unauthorized","error":"UnauthorizedError"}

有人有工作代码或知道为什么我会收到此消息?

4

2 回答 2

2

现在我正在使用yandex-disk包。它足以满足我的目的。

我的步骤:

  1. 在 Yandex Oath Service 中注册应用程序。之后,我可以获得有关我的应用程序的信息
  2. 通过调用 this实现获取 Oath Token 的访问方法。
  3. npm i yandex 磁盘
  4. 将代码插入 index.js

    const YandexDisk = require('yandex-disk').YandexDisk;
    const disk = new YandexDisk('YourOathTokenHere');
    console.log('disk', disk);
    disk.readdir('/', (err, response) => {
        console.log('callback error', err);
        console.log('callback response', response);
    });
    
于 2018-02-10T13:35:09.740 回答
0

只需包含这样的授权标头:

axios.get(encodeURI(`https://cloud-api.yandex.net:443/v1/disk/resources?path=${path}`), {
        headers: {
            'Authorization': `OAuth ${token}`
        }
    }).then((res) => {
        console.log(res);
    }).catch((err) => {
        console.log(err);
    });
于 2019-10-09T07:00:59.867 回答