主頁(yè) > 知識(shí)庫(kù) > Html5實(shí)現(xiàn)文件異步上傳功能

Html5實(shí)現(xiàn)文件異步上傳功能

熱門標(biāo)簽:飛亞外呼系統(tǒng) 電視購(gòu)物電銷外呼系統(tǒng) 聯(lián)通400電話申請(qǐng) 貸款電銷人工和機(jī)器人哪個(gè)好 西寧智能外呼系統(tǒng)加盟 杭州營(yíng)銷電銷機(jī)器人供應(yīng)商 百應(yīng)電銷機(jī)器人產(chǎn)業(yè) 高德地圖標(biāo)注賓館位置 電話機(jī)器人如何

1 簡(jiǎn)介

開發(fā)文件上傳功能從來(lái)不是一件愉快的事,異步上傳更是如此,使用過(guò)iframe和Flash的上傳方案,也都感覺十分的別扭。本文簡(jiǎn)要簡(jiǎn)紹利用Html5的FormData實(shí)現(xiàn)文件的異步上傳,還可以實(shí)現(xiàn)上傳進(jìn)度條和文件大小驗(yàn)證等。服務(wù)端使用springMVC的方案進(jìn)行處理。

2 Html代碼

<form id="myForm">
    <input type="file" id="u_photo" name="u_photo" />
    <input type="button" id="submit-btn" value="上傳" />
</form>

3 JQuery上傳

$("#submit-btn").on('click', function() {
    $.ajax({
        url:"/test/upload",
        type:"post",
        data:new FormData($("#myForm").get(0)),
        //十分重要,不能省略
        cache: false,
        processData: false,
        contentType: false,
        success: function () {
            alert("上傳成功!");
        }
    });
});

4 JQuery文件大小驗(yàn)證

文件大小的及相應(yīng)行為的控制,需根據(jù)需要自行處理,本方法只是示例方法。

$('#u_photo').on('change', function() {
    var file = this.files[0];
    if (file.size > 1024*1000) {
        alert('文件最大1M!')
    }
});

5 JQuery進(jìn)度條

在ajax方法中加入xhr即可控制上傳進(jìn)度,進(jìn)度條可以使用html5的progress也可使用其它的進(jìn)度條。顯示及隱藏進(jìn)度條需要自行處理,本方法只是簡(jiǎn)單介紹了進(jìn)度條的基本控制。

xhr: function() {
    var myXhr = $.ajaxSettings.xhr();
    if (myXhr.upload) {
        myXhr.upload.addEventListener('progress', function(e) {
            if (e.lengthComputable) {
                $('progress').attr({
                    value: e.loaded,
                    max: e.total,
                });
            }
        } , false);
    }
    return myXhr;
}

6 springMVC服務(wù)端

6.1 maven依賴

<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.5</version>
</dependency>
<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.3.2</version>
</dependency>

6.2 servlet-context.xml

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver" />

6.3 Controller

示例程序,并未給出文件驗(yàn)證,存儲(chǔ)及處理的相應(yīng)代碼。

@RequestMapping(value="/test/upload",method = RequestMethod.POST)
@ResponseBody
public String upload(@RequestParam("u_photo") MultipartFile u_photo) {
    System.out.println("u_photo="+u_photo.getSize());
    return "ok";
}

7 兼容性

IE 10+, Firefox 4.0+, Chrome 7+, Safari 5+, Opera 12+

8 推薦閱讀

如果對(duì)上述方案不滿意,推薦使用如下的解決方案:

JQuery File Uploader

以上所述是小編給大家介紹的Html5實(shí)現(xiàn)文件異步上傳功能,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

標(biāo)簽:玉溪 撫州 煙臺(tái) 晉中 安慶 牡丹江 內(nèi)蒙古 邯鄲

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Html5實(shí)現(xiàn)文件異步上傳功能》,本文關(guān)鍵詞  Html5,實(shí)現(xiàn),文件,異步,上傳,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Html5實(shí)現(xiàn)文件異步上傳功能》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Html5實(shí)現(xiàn)文件異步上傳功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章