項目開發過程中遇到一個需求,運營人員需要上傳圖片到七牛雲,最開始的做法是,后台對接七牛,然后出一個接口,前端調用接口,先將圖片傳到后台,然后后台再上傳七牛雲,用的過程中發現,圖片小的情況下還好,圖片一旦到了幾十兆甚至幾百兆的時候就很慢,前端上傳圖片到后台需要一定時間,后端上傳到七牛又需要一段時間,很是麻煩,所以果斷改成了前端直接上傳七牛,直接上代碼
<!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, // 禁止自動發送上傳統計信息到七牛,默認允許發送
runtimes: 'html5,flash,html4', // 上傳模式,依次退化
browse_button: 'uploadImage', // 上傳選擇的點選按鈕,必需
container: 'container', // 上傳區域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三個參數中必須有一個被設置,uptoken是上傳憑證,由其他程序生成;uptoken_url是提供了獲取上傳憑證的地址,如果需要定制獲取uptoken的過程則可以設置uptoken_func;其優先級為uptoken > uptoken_url > uptoken_func
domain: 'XXX', // bucket域名,下載資源時用到,必需
get_new_uptoken: true, // 設置上傳文件的時候是否每次都重新獲取新的uptoken
auto_start: true, // 選擇文件后自動上傳,若關閉需要自己綁定事件觸發上傳
max_retries: 3, // 上傳失敗最大重試次數
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(); //創建一個Image對象,實現圖片的預下載
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事件中是不會執行的
2、分塊上傳時,一些分辨率或者色彩密度較高的圖片不支持切片
3、點擊選擇文件之后函數不執行的原因可能有:1)browse_button和container的值寫成了class,但是不支持class,需要改成id名;2)函數沒有初始化;3)后台返回來的token字段不正確,如果是這個原因,可以嘗試將token改為uptoken
最后附上 七牛官方的上傳demo
1、這個uploader初始化的時候如果放在change事件中是不會執行的
2、分塊上傳時,一些分辨率或者色彩密度較高的圖片不支持切片
3、點擊選擇文件之后函數不執行的原因可能有:1)browse_button和container的值寫成了class,但是不支持class,需要改成id名;2)函數沒有初始化;3)后台返回來的token字段不正確,如果是這個原因,可以嘗試將token改為uptoken
最后附上 七牛官方的上傳demo
作者:Eternal丶
鏈接:https://www.jianshu.com/p/1e53415afb09

