Uploader Plugin for Object Storage Service
目前仅支持alioss,后期会增加其他云服务平台
支持列表:
- alioss
上传支持多种实现,根据云服务商提供支持的不同而不同。 目前使用alioss上传支持
- alioss官方Client
- upload.alioss.js
- upload.alioss.compress.js 支持压缩图片的压缩操作
- plupload(更多搭建说明)
- upload.plupload.js 自带压缩文件的支持,不过对于flash、sliverlight需要设置相关的资源文件
html导入资源
- alioss
<script src="//gosspublic.alicdn.com/aliyun-oss-sdk-4.4.4.min.js"></script> <script src="/js/1.0.0/upload.alioss.compress.js"></script>
- plupload
<script src="/js/1.0.0/upload.plupload.js"></script>
脚本上传文件
var uploader = new Uploader({
token: 'http://oss.stsserver.com/token'
});
uploader.upload(file, {
before: function(name) {
console.log('before', name);
},
progress: function(name, p) {
console.log('progress', name, p);
},
success: function(name, res) {
console.log('success', name, res);
document.getElementById('img').src = res.url;
},
error: function(name, err) {
console.log('error', name, err);
}
//if you use upload.alioss.js, imageCompress will be ignored
, imageCompress: {
maxWidth: 200
}
});
Uploader构造配置 new Uploader(option)
- token token主要是用于保存对于第三方云存储服务的授权信息,支持两种方式:
- 使用临时授权访问的服务,这种情况下只需要配置对应的链接即可。(推荐此模式,确保数据更加安全) 授权服务搭建说明
{
auth: 'http://auth.token-server.com/token/path'
}
使用临时授权服务,返回的数据格式和下面的格式相同即可。
- 通过配置设置相关的访问授权数据 不过针对两种模式有两种不同的数据数据格式
alioss官方客户端的认证官方文档
{
token: {
accessKeyId: 'AccessKeyId',
accessKeySecret: 'AccessKeySecret',
stsToken: 'SecurityToken', // sts token mode use this node
Expiration: 'Token Expiration Time',
region: 'oss region',
bucket: 'oss bucket name',
static: 'cnd domain' // bucket.region.ossdomain.com => your.cdn-domain.com
}
}
pluoload的认证数据格式官方文档
{
token: {
policy: 'policyBase64',
OSSAccessKeyId: 'accessKeyId',
success_action_status: '200',
signature: 'signature',
Expiration: 'expiration',
bucket: 'bucketName',
region: 'bucketRegion',
static: 'cnd domain' // bucket.region.ossdomain.com => your.cdn-domain.com
}
}
static
用于替换上传成功后的链接,默认使用云存储格式的链接方式Expiration
用于设置Token失效时间,如果失效会自动更新。如果未设置,默认长期有效- 其他配置参照相关配置的说明控制
data
Filename
String | Function, value as you set, default 'year/month/date/hour/timeInterval_random.fileType'.option
json objectprefix
file name prefix strsuffix
file name suffix strbefore
function, invoke before uploadprogress
function, get upload progresssuccess
function, invoke after upload file successerror
function, get some errorimageCompress
quality
image quality 1 ~ 100outputImageType
default 'image/jpeg', image/png is optionexif
boolean, save exif info after compressmaxWidth
Number image max widthmaxHeight
Number image max heightmaxSize
Number image max size (false or number > 0) if maxWidth,maxHeight,maxSize are undefined,use default maxPixels(500*600=300000)backgroundColor
String background color, default '#fff', it works that png convert to jpeg
option.imageCompress.maxSize
and option.imageCompress.backgroundColor
not working for plupload client