js上傳圖片到七牛雲存儲

項目開發過程當中遇到一個需求,運營人員須要上傳圖片到七牛雲,最開始的作法是,後臺對接七牛,而後出一個接口,前端調用接口,先將圖片傳到後臺,而後後臺再上傳七牛雲,用的過程當中發現,圖片小的狀況下還好,圖片一旦到了幾十兆甚至幾百兆的時候就很慢,前端上傳圖片到後臺須要必定時間,後端上傳到七牛又須要一段時間,非常麻煩,因此果斷改爲了前端直接上傳七牛,直接上代碼
<!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>

 

須要注意的是:
一、這個uploader初始化的時候若是放在change事件中是不會執行的
二、分塊上傳時,一些分辨率或者色彩密度較高的圖片不支持切片
三、點擊選擇文件以後函數不執行的緣由可能有:1)browse_button和container的值寫成了class,可是不支持class,須要改爲id名;2)函數沒有初始化;3)後臺返回來的token字段不正確,若是是這個緣由,能夠嘗試將token改成uptoken

最後附上 七牛官方的上傳demo


做者:Eternal丶
連接:https://www.jianshu.com/p/1e53415afb09

html

相關文章
相關標籤/搜索