項目開發(fā)過程中遇到一個需求肠缨,運營人員需要上傳圖片到七牛云,最開始的做法是盏阶,后臺對接七牛晒奕,然后出一個接口,前端調(diào)用接口名斟,先將圖片傳到后臺脑慧,然后后臺再上傳七牛云,用的過程中發(fā)現(xiàn)砰盐,圖片小的情況下還好闷袒,圖片一旦到了幾十兆甚至幾百兆的時候就很慢,前端上傳圖片到后臺需要一定時間岩梳,后端上傳到七牛又需要一段時間囊骤,很是麻煩,所以果斷改成了前端直接上傳七牛冀值,直接上代碼
<!doctype html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>js上傳圖片到七牛</title>
<style>
#container{
width:200px;
height:200px;
border:1px solid #9d9d9d;
border-radius: 6px;
margin:50px auto;
position: relative;
overflow: hidden;
}
.upload-progress{
width:100%;
height:100%;
position: absolute;
top:0;
left:0;
background: rgba(0,0,0,0.5);
z-index: 5;
color:#fff;
line-height: 200px;
text-align: center;
display: none;
}
#uploadImage{
width:100%;
height:100%;
position: absolute;
top:0;
left:0;
z-index: 2;
text-align: center;
line-height: 200px;
cursor: pointer;
}
#container img{
width:100%;
position: absolute;
top:0;
left:0;
z-index: 1;
}
</style>
</head>
<body>
<div id="container">
<div id="uploadImage">選擇文件</div>
<div class="upload-progress"></div>
</div>
<script src="/moxie.js"></script>
<script src="/plupload.min.js"></script>
<script src="/qiniu.js"></script>
<script>
var uploader = Qiniu.uploader({
disable_statistics_report: false, // 禁止自動發(fā)送上傳統(tǒng)計信息到七牛也物,默認允許發(fā)送
runtimes: 'html5,flash,html4', // 上傳模式,依次退化
browse_button: 'uploadImage', // 上傳選擇的點選按鈕池摧,必需
container: 'container', // 上傳區(qū)域DOM ID焦除,默認是browser_button的父元素
max_file_size: '100mb', // 最大文件體積限制
flash_swf_url: 'Moxie.swf', // 引入flash,相對路徑
dragdrop: false, // 關閉可拖曳上傳
chunk_size: '4mb', // 分塊上傳時作彤,每塊的體積
multi_selection: !(moxie.core.utils.Env.OS.toLowerCase() === "ios"),
uptoken_url: 'XXX', // 在初始化時膘魄,uptoken,uptoken_url竭讳,uptoken_func三個參數(shù)中必須有一個被設置,uptoken是上傳憑證创葡,由其他程序生成;uptoken_url是提供了獲取上傳憑證的地址,如果需要定制獲取uptoken的過程則可以設置uptoken_func;其優(yōu)先級為uptoken > uptoken_url > uptoken_func
domain: 'XXX', // bucket域名绢慢,下載資源時用到灿渴,必需
get_new_uptoken: true, // 設置上傳文件的時候是否每次都重新獲取新的uptoken
auto_start: true, // 選擇文件后自動上傳,若關閉需要自己綁定事件觸發(fā)上傳
max_retries: 3, // 上傳失敗最大重試次數(shù)
save_key: true,
resize: { // 想限制上傳圖片尺寸胰舆,直接用resize這個屬性
width: 300,
height: 300
},
init: {
'FilesAdded': function(up, files) { // 文件添加進隊列后骚露,處理相關的事情
plupload.each(files, function(file) {
console.log(file)
});
},
'BeforeUpload': function(up, file) { // 每個文件上傳前,處理相關的事情
console.log("開始上傳之前");
$(".upload-progress").show();
},
'UploadProgress': function(up, file) { // 每個文件上傳時缚窿,處理相關的事情
console.log("上傳中");
$(".upload-progress").html("上傳進度:"+file.percent + "%");
},
'FileUploaded': function(up, file, info) { // 每個文件上傳成功后棘幸,處理相關的事情
console.log("上傳成功");
$(".upload-progress").hide();
var img = new Image(); //創(chuàng)建一個Image對象,實現(xiàn)圖片的預下載
img.src = "http://qiniu.com/"+res.key;
$("#container").append(img);
},
'Error': function(up, err, errTip) {
console.log("上傳出錯")
},
'UploadComplete': function() {
//隊列文件處理完畢后倦零,處理相關的事情
}
}
});
</script>
</body>
</html>
需要注意的是:
1误续、這個uploader初始化的時候如果放在change事件中是不會執(zhí)行的
2吨悍、分塊上傳時,一些分辨率或者色彩密度較高的圖片不支持切片
3蹋嵌、點擊選擇文件之后函數(shù)不執(zhí)行的原因可能有:1)browse_button和container的值寫成了class育瓜,但是不支持class,需要改成id名栽烂;2)函數(shù)沒有初始化躏仇;3)后臺返回來的token字段不正確,如果是這個原因腺办,可以嘗試將token改為uptoken
最后附上七牛官方的上傳demo