5. 文件下载¶
NOS Node SDK提供了丰富的文件下载接口,用户可以通过以下方式从NOS获取文件:
- 下载文件到内存
- 下载到本地文件
- 指定范围下载
- 条件下载
5.1. 下载文件到内存¶
您可以通过NosClient.get_object_stream接口下载文件到内存,可以参考以下代码:
var map = {
bucket: 'bucketName', //桶名
key: 'objectName' //对象名
};
var cb = function(result) {
//打印statusCode
console.log(result['statusCode']);
//打印content-length
console.log(result['headers']['content-length']);
//获取流
var stream = result['stream'];
//处理流
......
}
try {
nosclient.get_object_stream(map, cb);
}
catch(err) {
console.log("Failed with code:" + err.code);
}
回调函数的参数result中包含的内容示例:
statusCode: 200
headers: {
'x-nos-request-id': 'aa2402d20af100000155fb6d6cd915fb',
'content-type': 'application/octet-stream; charset=UTF-8',
etag: '926d74ef88054b6586a5530c5c6606b3',
'content-disposition': 'inline; filename="objectName"',
'last-modified': 'Mon, 18 Jul 2016 08:33:12 Asia/Shanghai',
'cache-control': 'no-cache',
'content-length': '18',
connection: 'close',
server: 'Jetty(6.1.11)' }
5.2. 下载文件到本地文件¶
您可以通过NosClient.get_object_file接口下载文件到本地文件,可以参考以下代码:
var map = {
bucket: 'bucketName', //桶名
key: 'objectName', //对象名
path: 'destpath' //本地文件路径(包括文件名)
};
var cb = function(result) {
console.log(result);
}
try {
nosclient.get_object_file(map, cb);
}
catch(err) {
console.log("Failed with code:" + err.code);
}
回调函数的参数result中包含的内容示例:
statusCode: 200
headers: {
'x-nos-request-id': 'aa2402d20af100000155fb6d6cd915fb',
'content-type': 'application/octet-stream; charset=UTF-8',
etag: '926d74ef88054b6586a5530c5c6606b3',
'content-disposition': 'inline; filename="objectName"',
'last-modified': 'Mon, 18 Jul 2016 08:33:12 Asia/Shanghai',
'cache-control': 'no-cache',
'content-length': '18',
connection: 'close',
server: 'Jetty(6.1.11)' }
5.3. 指定范围下载¶
如果存储在NOS中的文件较大,并且您只需要其中的一部分内容,您可以使用范围下载,下载指定范围的数据,如果指定的下载范围为”0-100”,则返回结果为第0字节到第100字节的数据,返回的数据包含第100字节,即bytes=0-100,如果指定的范围无效则下载整个文件,以下源代码获取bytes=0-100字节的内容,可以参考以下代码:
var map = {
bucket: 'bucketName', //桶名
key: 'objectName', //对象名
path: 'destpath', //本地文件路径(包括文件名)
rang: 'bytes=0-100' //文件范围
};
var cb = function(result) {
console.log(result);
}
try {
nosclient.get_object_file(map, cb);
}
catch(err) {
console.log(""Failed with code: " + err.code");
}
回调函数的参数result中包含的内容示例:
statusCode: 200
headers: {
'x-nos-request-id': 'aa2402d20af100000155fb6d6cd915fb',
'content-type': 'application/octet-stream; charset=UTF-8',
etag: '926d74ef88054b6586a5530c5c6606b3',
'content-disposition': 'inline; filename="objectName"',
'last-modified': 'Mon, 18 Jul 2016 08:33:12 Asia/Shanghai',
'cache-control': 'no-cache',
'content-length': '180',
connection: 'close',
server: 'Jetty(6.1.11)' }
Attention
- 下载内容也可以存储到文件中
- 注意下载的区间为闭区间
5.4. 条件下载¶
下载文件时,可以指定限定条件,满足限定条件时下载,不满足时报错,不下载文件。可以使用的限定条件如下:
参数 | 说明 |
---|---|
if_modified_since | 如果指定的时间早于实际修改时间,则正常传送。否则返回错误 |
var map = {
bucket: 'bucketName', //桶名
key: 'objectName', //对象名
path: 'destpath', //本地文件路径(包括文件名)
if_modified_since: 'Fri, 13 Nov 2016 14:47:53 GMT' //指定时间
};
var cb = function(result) {
console.log(result);
}
try {
nosclient.get_object_file(map, cb);
}
catch(err) {
console.log(""Failed with code: " + err.code");
}
回调函数的参数result中包含的内容示例:
statusCode: 200
headers: {
'x-nos-request-id': 'aa2402d20af100000155fb6d6cd915fb',
'content-type': 'application/octet-stream; charset=UTF-8',
etag: '926d74ef88054b6586a5530c5c6606b3',
'content-disposition': 'inline; filename="objectName"',
'last-modified': 'Mon, 18 Jul 2016 08:33:12 Asia/Shanghai',
'cache-control': 'no-cache',
'content-length': '18',
connection: 'close',
server: 'Jetty(6.1.11)' }
Attention
- 下载内容也可以存储到文件中