【原創(chuàng)】js上傳圖片到七牛云存儲

項目開發(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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末钙态,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子菇晃,更是在濱河造成了極大的恐慌册倒,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡艇肴,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門崇呵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人馅袁,你說我怎么就攤上這事域慷。” “怎么了汗销?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵犹褒,是天一觀的道長。 經(jīng)常有香客問我弛针,道長叠骑,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任削茁,我火速辦了婚禮宙枷,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘茧跋。我一直安慰自己慰丛,他們只是感情好,可當我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布瘾杭。 她就那樣靜靜地躺著诅病,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上睬隶,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天,我揣著相機與錄音页徐,去河邊找鬼苏潜。 笑死,一個胖子當著我的面吹牛变勇,可吹牛的內(nèi)容都是我干的恤左。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼搀绣,長吁一口氣:“原來是場噩夢啊……” “哼飞袋!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起链患,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤巧鸭,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后麻捻,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體纲仍,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年贸毕,在試婚紗的時候發(fā)現(xiàn)自己被綠了郑叠。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡明棍,死狀恐怖乡革,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情摊腋,我是刑警寧澤沸版,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站兴蒸,受9級特大地震影響推穷,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜类咧,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一馒铃、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧痕惋,春花似錦区宇、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至堕虹,卻和暖如春卧晓,著一層夾襖步出監(jiān)牢的瞬間芬首,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工逼裆, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留郁稍,地道東北人。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓胜宇,卻偏偏與公主長得像耀怜,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子桐愉,可洞房花燭夜當晚...
    茶點故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內(nèi)容