JavaScript Client API参考文档 Slack

初使化Minio Client object.

Minio

var Minio = require('minio')

var minioClient = new Minio.Client({
    endPoint: 'play.minio.io',
    port: 9000,
    useSSL: true,
    accessKey: 'Q3AM3UQ867SPQQA43P2F',
    secretKey: 'zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG'
});

AWS S3

var Minio = require('minio')

var s3Client = new Minio.Client({
    endPoint:  's3.amazonaws.com',
    accessKey: 'YOUR-ACCESSKEYID',
    secretKey: 'YOUR-SECRETACCESSKEY'
})
操作存储桶 操作对象 Presigned操作 存储桶策略/通知
makeBucket getObject presignedUrl getBucketNotification
listBuckets getPartialObject presignedGetObject setBucketNotification
bucketExists fGetObject presignedPutObject removeAllBucketNotification
removeBucket putObject presignedPostPolicy getBucketPolicy
listObjects fPutObject setBucketPolicy
listObjectsV2 copyObject listenBucketNotification
listIncompleteUploads statObject
removeObject
removeIncompleteUpload

1. 构造函数

new Minio.Client ({endPoint, port, useSSL, accessKey, secretKey})

new Minio.Client ({endPoint, port, useSSL, accessKey, secretKey})
初使化一个新的client对象。

参数

参数 类型 描述
endPoint string endPoint是一个主机名或者IP地址。
port number TCP/IP端口号。可选,默认值是,如果是http,则默认80端口,如果是https,则默认是443端口。
accessKey string accessKey类似于用户ID,用于唯一标识你的账户。
secretKey string secretKey是你账户的密码。
useSSL bool 如果是true,则用的是https而不是http,默认值是true。
region string 设置该值以覆盖自动发现存储桶region。(可选)

示例

创建连接Minio Server的客户端

var Minio = require('minio')

var minioClient = new Minio.Client({
    endPoint: 'play.minio.io',
    port: 9000,
    useSSL: true,
    accessKey: 'Q3AM3UQ867SPQQA43P2F',
    secretKey: 'zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG'
});

创建连接AWS S3的客户端

var Minio = require('minio')

var s3Client = new Minio.Client({
    endPoint:  's3.amazonaws.com',
    accessKey: 'YOUR-ACCESSKEYID',
    secretKey: 'YOUR-SECRETACCESSKEY'
})

2. 操作存储桶

makeBucket(bucketName, region[, callback])

创建一个新的存储桶。

参数

参数 类型 描述
bucketName string 存储桶名称。
region string 存储桶被创建的region(地区),默认是us-east-1(美国东一区),下面列举的是其它合法的值:
us-east-1
us-west-1
us-west-2
eu-west-1
eu-central-1
ap-southeast-1
ap-northeast-1
ap-southeast-2
sa-east-1
cn-north-1
callback(err) function 回调函数,err做为错误信息参数。如果创建存储桶成功则err为null。如果没有传callback的话,则返回一个Promise对象。

示例

minioClient.makeBucket('mybucket', 'us-east-1', function(err) {
  if (err) return console.log('Error creating bucket.', err)
  console.log('Bucket created successfully in "us-east-1".')
})

listBuckets([callback])

列出所有存储桶。

参数

参数 类型 描述
callback(err, bucketStream) function 回调函数,第一个参数是错误信息。bucketStream是带有存储桶信息的流。如果没有传callback的话,则返回一个Promise对象。

bucketStream格式如下:-

参数 类型 描述
bucket.name string 存储桶名称
bucket.creationDate Date 存储桶创建时间。

示例

minioClient.listBuckets(function(err, buckets) {
  if (err) return console.log(err)
  console.log('buckets :', buckets)
})

bucketExists(bucketName[, callback])

验证存储桶是否存在。

参数

参数 类型 描述
bucketName string 存储桶名称。
callback(err) function 如果存储桶存在的话err就是null,否则err.codeNoSuchBucket。如果没有传callback的话,则返回一个Promise对象。

示例

minioClient.bucketExists('mybucket', function(err) {
  if (err) {
     if (err.code == 'NoSuchBucket') return console.log("bucket does not exist.")
     return console.log(err)
  }
  // if err is null it indicates that the bucket exists.
  console.log('Bucket exists.')
})

removeBucket(bucketName[, callback])

删除存储桶。

参数

参数 类型 描述
bucketName string 存储桶名称。
callback(err) function 如果存储桶删除成功则errnull。如果没有传callback的话,则返回一个Promise对象。

示例

minioClient.removeBucket('mybucket', function(err) {
  if (err) return console.log('unable to remove bucket.')
  console.log('Bucket removed successfully.')
})

listObjects(bucketName, prefix, recursive)

列出存储桶中所有对象。

参数

参数 类型 描述
bucketName string 存储桶名称。
prefix string 要列出的对象的前缀 (可选,默认值是'')。
recursive bool true代表递归查找,false代表类似文件夹查找,以'/'分隔,不查子文件夹。(可选,默认值是false

返回值

参数 类型 描述
stream Stream 存储桶中对象信息的流。

对象的格式如下:

参数 类型 描述
obj.name string 对象名称。
obj.prefix string 对象名称的前缀。
obj.size number 对象的大小。
obj.etag string 对象的etag值。
obj.lastModified Date 最后修改时间。

示例

var stream = minioClient.listObjects('mybucket','', true)
stream.on('data', function(obj) { console.log(obj) } )
stream.on('error', function(err) { console.log(err) } )

listObjectsV2(bucketName, prefix, recursive)

使用S3 listing objects V2版本API列出所有对象。

参数

参数 类型 描述
bucketName string 存储桶名称。
prefix string 要列出的对象的前缀。(可选,默认值是''
recursive bool true代表递归查找,false代表类似文件夹查找,以'/'分隔,不查子文件夹。(可选,默认值是false

返回值

参数 类型 描述
stream Stream 存储桶中对象信息的流。

对象的格式如下:

参数 类型 描述
obj.name string 对象名称。
obj.prefix string 对象名称的前缀。
obj.size number 对象的大小。
obj.etag string 对象的etag值。
obj.lastModified Date 最后修改时间。

示例

var stream = minioClient.listObjectsV2('mybucket','', true)
stream.on('data', function(obj) { console.log(obj) } )
stream.on('error', function(err) { console.log(err) } )

listIncompleteUploads(bucketName, prefix, recursive)

列出存储桶中未完整上传的对象。

参数

参数 类型 描述
bucketname string 存储桶名称。
prefix string 未完整上传的对象的前缀。(可选,默认值是'')。
recursive bool true代表递归查找,false代表类似文件夹查找,以'/'分隔,不查子文件夹。(可选,默认值是false

返回值

参数 类型 描述
stream Stream 对象格式如下:
参数 类型 描述
part.key string 对象名称。
part.uploadId string 对象的上传ID。
part.size Integer 未完整上传的对象的大小。

示例

var Stream = minioClient.listIncompleteUploads('mybucket', '', true)
Stream.on('data', function(obj) {
  console.log(obj)
})
Stream.on('end', function() {
  console.log('End')
})
Stream.on('error', function(err) {
  console.log(err)
})

3. 操作对象

getObject(bucketName, objectName[, callback])

下载对象。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
callback(err, stream) function 回调函数,第一个参数是错误信息。stream是对象的内容。如果没有传callback的话,则返回一个Promise对象。

示例

var size = 0
minioClient.getObject('mybucket', 'photo.jpg', function(err, dataStream) {
  if (err) {
    return console.log(err)
  }
  dataStream.on('data', function(chunk) {
    size += chunk.length
  })
  dataStream.on('end', function() {
    console.log('End. Total size = ' + size)
  })
  dataStream.on('error', function(err) {
    console.log(err)
  })
})

getPartialObject(bucketName, objectName, offset, length[, callback])

下载对象中指定区间的字节数组,并返回流。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
offset number offset是从第几个字节始
length number length是要下载的字节数组长度(可选值,如果为空的话则代表从offset一直到文件的末尾)。
callback(err, stream) function 回调函数,第一个参数是错误信息。stream是对象的内容。如果没有传callback的话,则返回一个Promise对象。

示例

var size = 0
// reads 30 bytes from the offset 10.
minioClient.getPartialObject('mybucket', 'photo.jpg', 10, 30, function(err, dataStream) {
  if (err) {
    return console.log(err)
  }
  dataStream.on('data', function(chunk) {
    size += chunk.length
  })
  dataStream.on('end', function() {
    console.log('End. Total size = ' + size)
  })
  dataStream.on('error', function(err) {
    console.log(err)
  })
})

fGetObject(bucketName, objectName, filePath[, callback])

下载并将对象保存成本地文件。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
filePath string 要写入的本地文件路径。
callback(err) function 如果报错的话,则会调用回调函数,传入err参数。 如果没有传callback的话,则返回一个Promise对象。

示例

var size = 0
minioClient.fGetObject('mybucket', 'photo.jpg', '/tmp/photo.jpg', function(err) {
  if (err) {
    return console.log(err)
  }
  console.log('success')
})

putObject(bucketName, objectName, stream, size, contentType[, callback])

从一个stream/Buffer中上传一个对象。

从stream中上传

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
stream Stream 可以读的流。
size number 对象的大小(可选)。
contentType string 对象的Content-Type(可选,默认是application/octet-stream)。
callback(err, etag) function 如果err不是null则代表有错误,etag string是上传的对象的etag值。如果没有传callback的话,则返回一个Promise对象。

示例

单个对象的最大大小限制在5TB。putObject在对象大于5MiB时,自动使用multiple parts方式上传。这样的话,当上传失败的时候,客户端只需要上传未成功的部分即可(类似断点上传)。上传的对象使用MD5SUM签名进行完整性验证。

var Fs = require('fs')
var file = '/tmp/40mbfile'
var fileStream = Fs.createReadStream(file)
var fileStat = Fs.stat(file, function(err, stats) {
  if (err) {
    return console.log(err)
  }
  minioClient.putObject('mybucket', '40mbfile', fileStream, stats.size, function(err, etag) {
    return console.log(err, etag) // err should be null
  })
})
从"Buffer"或者"string"上传

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
string or Buffer Stream or Buffer 字符串可者缓冲区
contentType string 对象的Content-Type(可选,默认是application/octet-stream)。
callback(err, etag) function 如果err不是null则代表有错误,etag string是上传的对象的etag值。

示例

var buffer = 'Hello World'
minioClient.putObject('mybucket', 'hello-file', buffer, function(err, etag) {
  return console.log(err, etag) // err should be null
})

fPutObject(bucketName, objectName, filePath, contentType[, callback])

上传文件。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
filePath string 要上传的文件路径。
contentType string 对象的Content-Type。
callback(err, etag) function 如果err不是null则代表有错误,etag string是上传的对象的etag值。如果没有传callback的话,则返回一个Promise对象。

示例

var file = '/tmp/40mbfile'
minioClient.fPutObject('mybucket', '40mbfile', file, 'application/octet-stream', function(err, etag) {
  return console.log(err, etag) // err should be null
})

copyObject(bucketName, objectName, sourceObject, conditions[, callback])

将源对象拷贝到指定存储桶的新对象中。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
sourceObject string 源对象的名称
conditions CopyConditions 允许拷贝需要满足的条件。
callback(err, {etag, lastModified}) function 如果err不是null则代表有错误,etag string是上传的对象的etag值,lastModified Date是新拷贝对象的最后修改时间。如果没有传callback的话,则返回一个Promise对象。

示例

var conds = new Minio.CopyConditions()
conds.setMatchETag('bd891862ea3e22c93ed53a098218791d')
minioClient.copyObject('mybucket', 'newobject', '/mybucket/srcobject', conds, function(e, data) {
  if (e) {
    return console.log(e)
  }
  console.log("Successfully copied the object:")
  console.log("etag = " + data.etag + ", lastModified = " + data.lastModified)
})

statObject(bucketName, objectName[, callback])

获取对象的元数据。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
callback(err, stat) function 如果err不是null则代表有错误,stat含有对象的元数据信息,格式如下所示。如果没有传callback的话,则返回一个Promise对象。
参数 类型 描述
stat.size number 对象的大小。
stat.etag string 对象的etag值。
stat.contentType string 对象的Content-Type。
stat.lastModified string Last 最后修改时间。

示例

minioClient.statObject('mybucket', 'photo.jpg', function(err, stat) {
  if (err) {
    return console.log(err)
  }
  console.log(stat)
})

removeObject(bucketName, objectName[, callback])

删除一个对象。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
callback(err) function 如果err不是null则代表有错误。如果没有传callback的话,则返回一个Promise对象。

示例

minioClient.removeObject('mybucket', 'photo.jpg', function(err) {
  if (err) {
    return console.log('Unable to remove object', err)
  }
  console.log('Removed the object')
})

removeIncompleteUpload(bucketName, objectName[, callback])

删除一个未完整上传的对象。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
callback(err) function 如果err不是null则代表有错误。如果没有传callback的话,则返回一个Promise对象。

示例

minioClient.removeIncompleteUpload('mybucket', 'photo.jpg', function(err) {
  if (err) {
    return console.log('Unable to remove incomplete object', err)
  }
  console.log('Incomplete object removed successfully.')
})

4. Presigned操作

Presigned URLs用于对私有对象提供临时的上传/下载功能。

presignedUrl(httpMethod, bucketName, objectName, expiry[, reqParams, cb])

生成一个给指定HTTP方法('httpMethod')请求用的presigned URL。浏览器/移动端的客户端可以用这个URL进行下载,即使其所在的存储桶是私有的。这个presigned URL可以设置一个失效时间,默认值是7天。

参数

参数 类型 描述
httpMethod string http方法,put、get等。
bucketName string 存储桶名称。
objectName string 对象名称。
expiry number 失效时间(以秒为单位),默认是7天,不得大于七天。
reqParams object 请求参数。
callback(err, presignedUrl) function 如果err不是null则代表有错误。presignedUrl就是可临时上传/下载文件的URL。如果没有传callback的话,则返回一个Promise对象。

示例1

// presigned url for 'getObject' method.
// expires in a day.
minioClient.presignedUrl('GET', 'mybucket', 'hello.txt', 24*60*60, function(err, presignedUrl) {
  if (err) return console.log(err)
  console.log(presignedUrl)
})

示例2

// presigned url for 'listObject' method.
// Lists objects in 'myBucket' with prefix 'data'.
// Lists max 1000 of them.
minioClient.presignedUrl('GET', 'mybucket', '', 1000, {'prefix': 'data', 'max-keys': 1000}, function(err, presignedUrl) {
  if (err) return console.log(err)
  console.log(presignedUrl)
})

presignedGetObject(bucketName, objectName, expiry[, cb])

生成一个给HTTP GET请求用的presigned URL。浏览器/移动端的客户端可以用这个URL进行下载,即使其所在的存储桶是私有的。这个presigned URL可以设置一个失效时间,默认值是7天。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
expiry number 失效时间(以秒为单位),默认是7天,不得大于七天。
callback(err, presignedUrl) function 如果err不是null则代表有错误。presignedUrl就是可用于临时下载的URL。 如果没有传callback的话,则返回一个Promise对象。

示例

// expires in a day.
minioClient.presignedGetObject('mybucket', 'hello.txt', 24*60*60, function(err, presignedUrl) {
  if (err) return console.log(err)
  console.log(presignedUrl)
})

presignedPutObject(bucketName, objectName, expiry[, callback])

生成一个给HTTP PUT请求用的presigned URL。浏览器/移动端的客户端可以用这个URL进行上传,即使其所在的存储桶是私有的。这个presigned URL可以设置一个失效时间,默认值是7天。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectName string 对象名称。
expiry number 失效时间(以秒为单位),默认是7天,不得大于七天。
callback(err, presignedUrl) function 如果err不是null则代表有错误。presignedUrl用于使用PUT请求进行上传。如果没有传callback的话,则返回一个Promise对象。

示例

// expires in a day.
minioClient.presignedPutObject('mybucket', 'hello.txt', 24*60*60, function(err, presignedUrl) {
  if (err) return console.log(err)
  console.log(presignedUrl)
})

presignedPostPolicy(policy[, callback])

允许给POST请求的presigned URL设置条件策略。比如接收上传的存储桶名称、名称前缀、过期策略。

参数

参数 类型 描述
policy object 通过minioClient.newPostPolicy()创建的Policy对象。
callback(err, {postURL, formData}) function 如果err不是null则代表有错误。postURL用于使用post请求上传。formData是POST请求体中的键值对对象。如果没有传callback的话,则返回一个Promise对象。

创建策略:

var policy = minioClient.newPostPolicy()

设置上传策略:

// Policy restricted only for bucket 'mybucket'.
policy.setBucket('mybucket')

// Policy restricted only for hello.txt object.
policy.setKey('hello.txt')

或者

// Policy restricted for incoming objects with keyPrefix.
policy.setKeyStartsWith('keyPrefix')

var expires = new Date
expires.setSeconds(24 * 60 * 60 * 10)
// Policy expires in 10 days.
policy.setExpires(expires)

// Only allow 'text'.
policy.setContentType('text/plain')

// Only allow content size in range 1KB to 1MB.
policy.setContentLengthRange(1024, 1024*1024)

使用superagent通过浏览器POST你的数据:

minioClient.presignedPostPolicy(policy, function(err, data) {
  if (err) return console.log(err)

  var req = superagent.post(data.postURL)
  _.each(data.formData, function(value, key) {
    req.field(key, value)
  })

  // file contents.
  req.attach('file', '/path/to/hello.txt', 'hello.txt')

  req.end(function(err, res) {
    if (err) {
      return console.log(err.toString())
    }
    console.log('Upload successful.')
  })
})

5. 存储桶策略/通知

存储桶可以配置在指定事件类型和相应路径上触发通知。

getBucketNotification(bucketName[, cb])

获取指定存储桶名称的通知配置。

参数

参数 类型 描述
bucketName string 存储桶名称。
callback(err, bucketNotificationConfig) function 如果err不是null则代表有错误。bucketNotificationConfig是相应存储桶上的通知配置对象。如果没有传callback的话,则返回一个Promise对象。

示例

minioClient.getBucketNotification('mybucket', function(err, bucketNotificationConfig) {
  if (err) return console.log(err)
  console.log(bucketNotificationConfig)
})

setBucketNotification(bucketName, bucketNotificationConfig[, callback])

上传一个用户创建的通知配置,并绑定到指定的存储桶上。

参数

参数 类型 描述
bucketName string 存储桶名称。
bucketNotificationConfig BucketNotification 包含通知配置的Javascript对象。
callback(err) function 如果err不是null则代表有错误。如果没有传callback的话,则返回一个Promise对象。

示例

// Create a new notification object
var bucketNotification = new Notify.BucketNotification();

// Setup a new topic configuration
var arn = Notify.newARN('aws', 'sns', 'us-west-2', '408065449417', 'TestTopic')
var topic = new Notify.TopicConfig(arn)
topic.addFilterSuffix('.jpg')
topic.addFilterPrefix('myphotos/')
topic.addEvent(Notify.ObjectReducedRedundancyLostObject)
topic.addEvent(Notify.ObjectCreatedAll)

// Add the topic to the overall notification object
bucketNotification.addTopicConfiguration(topic)

minioClient.setBucketNotification('mybucket', bucketNotification, function(err) {
  if (err) return console.log(err)
  console.log('Success')
})

removeAllBucketNotification(bucketName[, callback])

删除指定存储桶上的通知配置。

参数

参数 类型 描述
bucketName string 存储桶名称。
callback(err) function 如果err不是null则代表有错误。如果没有传callback的话,则返回一个Promise对象。
minioClient.removeAllBucketNotification('my-bucketname', function(e) {
  if (e) {
    return console.log(e)
  }
  console.log("True")
})

listenBucketNotification(bucketName, prefix, suffix, events)

监听存储桶上的通知,可通过前缀、后缀、事件类型进行过滤。使用本API并不需要预先设置存储桶通知。这是Minio的一个扩展API,服务端基于过来的请求使用唯一ID自动注册或者取消注册。

返回一个EventEmitter对象,它可以广播一个通知事件。

停止监听,调用EventEmitterstop()方法。

参数

参数 类型 描述
bucketName string 存储桶名称。
prefix string 用于过滤通知的对象名称前缀。
suffix string 用于过滤通知的对象名称后缀。
events Array 在指定事件类型上开启通知。

这里是你要的完整示例,拿走不谢。

var listener = minioClient.listenBucketNotification('my-bucketname', 'photos/', '.jpg', ['s3:ObjectCreated:*'])
listener.on('notification', function(record) {
  // For example: 's3:ObjectCreated:Put event occurred (2016-08-23T18:26:07.214Z)'
  console.log('%s event occurred (%s)', record.eventName, record.eventTime)
  listener.stop()
})

getBucketPolicy(bucketName, objectPrefix[, callback])

获取指定存储桶的访问策略,如果objectPrefix不为空,则会取相应对象前缀上的访问策略。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectPrefix string 用于过滤的对象前缀,''代表整个存储桶。
callback(err, policy) function 如果err不是null则代表有错误。policy是存储桶策略的字符串表示(minio.Policy.NONEminio.Policy.READONLYminio.Policy.WRITEONLY,或者minio.Policy.READWRITE). 如果没有传callback的话,则返回一个Promise对象。
// Retrieve bucket policy of 'my-bucketname' that applies to all objects that
// start with 'img-'.
minioClient.getBucketPolicy('my-bucketname', 'img-', function(err, policy) {
  if (err) throw err

  console.log(`Bucket policy: ${policy}`)
})

setBucketPolicy(bucketName, objectPrefix, bucketPolicy[, callback])

设置指定存储桶的策略。如果objectPrefix不为空,则会给符合该前缀的对象(们)设置策略。

参数

参数 类型 描述
bucketName string 存储桶名称。
objectPrefix string 要设置访问策略的对象前缀。''代表整个存储桶。
bucketPolicy string 存储桶策略。可选值有:minio.Policy.NONEminio.Policy.READONLYminio.Policy.WRITEONLY或者minio.Policy.READWRITE
callback(err) function 如果err不是null则代表有错误。如果没有传callback的话,则返回一个Promise对象。
// Set the bucket policy of `my-bucketname` to `readonly` (only allow retrieval),
// but only for objects that start with 'img-'.
minioClient.setBucketPolicy('my-bucketname', 'img-', minio.Policy.READONLY, function(err) {
  if (err) throw err

  console.log('Set bucket policy to \'readonly\'.')
})

6. 了解更多