jquery.fileupload 使用

1官辈、頁(yè)面部分
引入的樣式溉知、js

jquery.fileupload.css
jquery-1.8.2.min.js
jquery.ui.widget.js
jquery.fileupload.js

頁(yè)面

<div class="btn btn-primary btn-sm fileinput-button" id="hide-button">
  <i class="glyphicon glyphicon-plus"></i>
  <span>上傳</span>
  <input id="imageFile" type="file" name="imageFile">
</div>

綁定事件

$('#' + fileId).fileupload({
    url: '/upload/image?type=' + type,
    add: function (e, data) {
          var uploadErrors = [];
          var acceptFileTypes = /^image\/(png|jpe?g)$/i;
          //文件類型判斷
          if (!acceptFileTypes.test(data.originalFiles[0]['type'])) {
             return false;
          }
         //文件大小判斷
          if (data.originalFiles[0]['size'] > 5000 * 1024) {
               return false;
          }
          if (uploadErrors.length > 0) {
                    return false;
                } else {
                    data.submit();
                }
          },
          done: function (e, data) {
                ......
          }
 });

2女器、java部分

@RestController
@RequestMapping("/file")
public class FileController {
    private final Logger logger = LoggerFactory.getLogger(getClass());

    @Value("${app.file.upload.server.origin}")
    private String origin;
    @Value("${app.file.upload.server.path}")
    private String realPath;
    @Value("${app.file.upload.dir.userPicture}")
    private String userPicturePath;
    @Value("${app.file.upload.size.max.image}")
    private int imageFileMaxSize;

    @PostMapping("/upload/image")
    public Result uploadImage(@RequestParam MultipartFile imageFile) {
        validateImageFile(imageFile);
        String dateDIR = DateFormatUtils.format(new Date(), "yyyyMMdd");
        String path = userPicturePath + dateDIR + "/";
        // 為上傳的文件進(jìn)行重命名(避免同名文件的相互覆蓋)使用UUID + 文件后綴
        String suffix = imageFile.getOriginalFilename().substring(imageFile.getOriginalFilename().lastIndexOf("."));
        String fileName = UUID.randomUUID().toString() + suffix;
        File file = new File(realPath + path + fileName);
        if (!file.getParentFile().exists()) {
            file.mkdirs();
        }
        //將臨時(shí)文件保存到磁盤
        try {
            imageFile.transferTo(file);
        } catch (IOException e) {
            logger.error("文件上傳失敗", e);
            throw new ServiceException("上傳失敗:" + e.getMessage());
        }
        Map<Object, Object> data = Maps.newLinkedHashMap();
        data.put("url", origin + path + fileName);
        return ResultGenerator.genSuccessResult(data);
    }

    private void validateImageFile(MultipartFile imageFile) throws ServiceException {
        //校驗(yàn)類型
        if (imageFile.getContentType().indexOf("image") == -1) {
            throw new ServiceException("上傳失敗什湘,僅支持圖片類型埠通!");
        }
        if (imageFile.getSize() > (imageFileMaxSize * 1024 * 1024)) {
            throw new ServiceException("上傳失敗赎离,文件大小不能超過(guò)" + imageFileMaxSize + "MB!");
        }
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末端辱,一起剝皮案震驚了整個(gè)濱河市梁剔,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌舞蔽,老刑警劉巖荣病,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異喷鸽,居然都是意外死亡众雷,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門做祝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人鸡岗,你說(shuō)我怎么就攤上這事混槐。” “怎么了轩性?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵声登,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我揣苏,道長(zhǎng)悯嗓,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任卸察,我火速辦了婚禮脯厨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘坑质。我一直安慰自己合武,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布涡扼。 她就那樣靜靜地躺著稼跳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪吃沪。 梳的紋絲不亂的頭發(fā)上汤善,一...
    開(kāi)封第一講書(shū)人閱讀 49,185評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼红淡。 笑死不狮,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的锉屈。 我是一名探鬼主播荤傲,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼颈渊!你這毒婦竟也來(lái)了遂黍?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤俊嗽,失蹤者是張志新(化名)和其女友劉穎雾家,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體绍豁,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡芯咧,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了竹揍。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片敬飒。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖芬位,靈堂內(nèi)的尸體忽然破棺而出无拗,到底是詐尸還是另有隱情,我是刑警寧澤昧碉,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布英染,位于F島的核電站,受9級(jí)特大地震影響被饿,放射性物質(zhì)發(fā)生泄漏四康。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一狭握、第九天 我趴在偏房一處隱蔽的房頂上張望闪金。 院中可真熱鬧,春花似錦哥牍、人聲如沸毕泌。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)撼泛。三九已至,卻和暖如春澡谭,著一層夾襖步出監(jiān)牢的瞬間愿题,已是汗流浹背损俭。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留潘酗,地道東北人杆兵。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像仔夺,于是被迫代替她去往敵國(guó)和親琐脏。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,527評(píng)論 25 707
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理缸兔,服務(wù)發(fā)現(xiàn)日裙,斷路器,智...
    卡卡羅2017閱讀 134,601評(píng)論 18 139
  • 我們是流浪的船舶 家是溫暖的港灣 無(wú)論走到哪兒 總有一絲牽掛 千縈萬(wàn)繞連到我們身上 也許未來(lái)的路還很長(zhǎng) 或許充滿了...
    荒野里的鬼閱讀 183評(píng)論 0 6
  • 后來(lái)我活的利索隨性瀟灑 卻始終學(xué)不會(huì)像你這樣說(shuō)走就走 你是我枯水年紀(jì)里的一場(chǎng)雨 你來(lái)的酣暢淋漓 我淋的一病不起 當(dāng)...
    故夢(mèng)j閱讀 448評(píng)論 4 8