NOS Node.js SDK 实现了 NOS 对象操作接口,基于此 SDK 能方便快速地实现 JavaScript 应用程序来使用 NOS 的对象存储服务。
NOS 是网易云推出的对象存储服务,稳定可靠
主要原因是官方的 nos-node-sdk
有如下问题
在设计 API 的时候,遵循了一些设计原则。
{err: Error, data: xxx}
的结构,你只是想得到内容体,为何要返回这么多数据。Believe me, It's a Trouble.getObject({objectKey: 'key', bucket: 'bucket'})
而不是 getObject('key', 'bucket', options)
deleteObject(params).then(() => console.log('success')).catch(() => console.log('error'))
而不是 deleteObject(params).then(success => console.log(success))
import { NosClient } from '@xgheaven/nos-node-sdk'
const client = new NosClient({
accessKey: 'your-access-key',
accessSecret: 'your-access-secret',
endpoint: 'http://nos-eastchina1.126.net', // endpoint,不同地域不同
defaultBucket: 'nos-test', // 默认的 Bucket,如果不设置,那么需要在单独的每次请求中进行设置
})
client.putObject({
objectKey: 'test-file.txt',
body: Buffer.from('test'), // 支持 Buffer/Readable/string
}).then(() => {
return client.getObject({
objectKey: 'test-file.txt',
encode: 'utf-8', // 支持 'buffer' | 编码 | 'stream'
})
}).then(content => {
console.log(content)
})
client.listObject({
limit: 10
}).then(ret => {
console.log(ret)
// 所有的 List 操作接口返回的数据都是类似的,比如 listObject, listBucket, listParts, listMultipart
// ret 包括 items(元素),limit(请求的数量),nextMarker(下一个标记)
// 通过 limit 和 nextMarker 的配合,可以实现分页的效果
})
更多信息,请查看 API 文档(Typedoc generated).
----------------------|----------|----------|----------|----------|-------------------|
File | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s |
----------------------|----------|----------|----------|----------|-------------------|
All files | 94.11 | 80.34 | 92.86 | 95.22 | |
src | 98 | 94.12 | 100 | 98 | |
client.ts | 98 | 94.12 | 100 | 98 | 143 |
src/exts | 93.23 | 70.33 | 96.97 | 93.17 | |
bucket.ts | 96.23 | 85.71 | 100 | 96.15 | 62,85 |
multipart-upload.ts | 91.82 | 59.26 | 92.86 | 91.82 |... 74,276,277,278 |
object.ts | 93.18 | 72 | 100 | 93.1 |... 82,233,234,236 |
src/lib | 94.01 | 87.76 | 88.1 | 97.4 | |
authorization.ts | 100 | 83.33 | 100 | 100 | 29 |
constant.ts | 100 | 100 | 100 | 100 | |
error.ts | 100 | 80 | 100 | 100 | 3 |
request.ts | 100 | 100 | 100 | 100 | |
resource.ts | 94.12 | 81.25 | 100 | 100 | 14,48,67 |
util.ts | 91.67 | 95.45 | 83.33 | 95.29 | 32,33,34,126 |
src/type | 100 | 100 | 100 | 100 | |
bucket.ts | 100 | 100 | 100 | 100 | |
----------------------|----------|----------|----------|----------|-------------------|
项目还比较年轻,如果有任何考虑不周的地方欢迎大家进行反馈,我也会积极处理。 争取有一天能够替代原先的 SDK,减轻大家使用上的烦恼。
虽然不认为很多人都知道 NOS,哈哈哈
Generated using TypeDoc