SpringBoot實現(xiàn)上傳下載(一)

最近在學(xué)Springboot相關(guān)知識拼岳,這次用Springboot做了一個上傳下載的功能
上傳一個法律名及其發(fā)布的年份等信息炉菲,然后還要能上傳一個pdf文件(這里限制下上傳的后綴名就可以),上傳之后舶替,點擊操作中的下載,下載對應(yīng)的pdf文件。

預(yù)覽:


image.png
image.png

1.前期準(zhǔn)備

編輯器:IDEA/eclipse/myeclipse
layui文檔的bang助:layui開發(fā)使用文檔

如何使用IDEA創(chuàng)建Springboot項目

使用使用IDEA進(jìn)行資源標(biāo)記

根據(jù)項目結(jié)構(gòu)圖:


image.png

標(biāo)記java文件夾為Source root
resources為resources root
為了迎合SSM框架的習(xí)慣 創(chuàng)建web文件夾


image.png

配置web


image.png

詳細(xì)的pom.xml等配置可以參見我的項目目錄 這里不一一展開了 主要說一下各個目錄文件夾的作用氛堕。

resources目錄下的application.properties是spring相關(guān)配置文件夾
generatorConfig是逆向工程的配置文件
webapp目錄下 public是JS/json/css等靜態(tài)資源
upload是上傳文件存放的文件夾
WEB-INF是存放jsp等渲染的網(wǎng)頁模板文件的文件夾

2.架構(gòu)設(shè)計(MVC)

image.png

Model:dao+service+model三個包實現(xiàn)數(shù)據(jù)庫連接以及使用數(shù)據(jù)庫實現(xiàn)持久化存儲

View:webapp包下的jsp等網(wǎng)頁渲染文件

C:controller包下的多個控制器

3.數(shù)據(jù)庫設(shè)計

image.png

沒什么好說的 想說的都在圖里

4.Code

首先實現(xiàn)上傳功能。實現(xiàn)思路:使用layui提供給我們的upload Element野蝇。我們上傳這個文件讼稚,限制后綴名為pdf,限制上傳文件最大2048KB等绕沈。后臺則將上傳的File文件使用java的file.transferTo錄入upload包下锐想。

View層實現(xiàn):
layer.jsp:

   <div class="layui-form-item">
            <div class="layui-input-block">
                <div class="layui-upload">
                    <button type="button" class="layui-btn layui-btn-normal" id="test8">選擇文件</button>
                    <button type="button" class="layui-btn" id="upload">開始上傳</button>
                    <input type="hidden" name="fileName" id="fileName">
                </div>
            </div>
        </div>

以上控件組件

   layui.use(['element', 'form', 'table', 'layer', 'vip_table', 'laydate','upload'], function() {
        var form = layui.form,
            table = layui.table,
            layer = layui.layer,
            vipTable = layui.vip_table,
            element = layui.element,
            $ = layui.jquery;
        var laydate = layui.laydate;
        var upload = layui.upload;

 //上傳
        upload.render({
            elem: '#test8'
            ,url: 'layer/upload'
            ,auto: false
            //,multiple: true
            ,bindAction: '#upload'
            ,size: 2048 //最大允許上傳的文件大小 2M
            ,accept: 'file' //允許上傳的文件類型
            ,exts:'pdf'//只上傳pdf文檔
            ,done: function(res){
                console.log(res)
                if(res.code == 1){//成功的回調(diào)
                    //do something (比如將res返回的圖片鏈接保存到表單的隱藏域)
                    $('#set-add-put input[name="fileName"]').val(res.data.fileName);
                    $('#upload').hide();
                    layer.msg(res.msg, {
                        icon: 6
                    });
                }else if(res.code==2){
                    layer.msg(res.msg, {
                        icon: 5
                    });
                }
            }
        });

以上對upload的監(jiān)聽,并且對返回的狀態(tài)碼1(成功),2(失敗)做相應(yīng)處理乍狐。

Controller層:
LayerController:

 /**
     * 處理上傳文件方法請求
     * @param file 前臺上傳的文件對象
     * @return
     */
    @RequestMapping(value = "Index/layer/upload",method = RequestMethod.POST)
    @ResponseBody
    public  Map<String,Object> uploadOne(HttpServletRequest request,@RequestParam("file")MultipartFile file)
    {
       Map map=new HashMap();
        try {
            //上傳目錄地址
//            String uploadDir = request.getSession().getServletContext().getRealPath("upload");
            String uploadDir = request.getSession().getServletContext().getRealPath("/") +"upload/";
            //如果目錄不存在赠摇,自動創(chuàng)建文件夾
            File dir = new File(uploadDir);
            if(!dir.exists())
            {
                dir.mkdir();
            }
            //調(diào)用上傳方法
           String fileName=upload.executeUpload(uploadDir,file);
            uploadDir=uploadDir.substring(0,uploadDir.length()-1);
            map.put("fileName",fileName);
            map.put("dir",uploadDir);
        }catch (Exception e)
        {
            //打印錯誤堆棧信息
            e.printStackTrace();
            return api.returnJson(2,"上傳失敗",map);
        }

        return api.returnJson(1,"上傳成功",map);
    }

相關(guān)的工具類:
Api.java:

package com.example.sl.layer.util;

import com.example.sl.layer.model.Layer;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

//接口
//code=1 success 2 fail 3 warning
public class Api {
    public Map<String,Object> returnJson(int code, String msg){
        Map map=new HashMap();
        map.put("code",code);
        map.put("msg",msg);
        return map;
    }

    public Map<String,Object> returnJson(int code, String msg, List<Map> data){
        Map map=new HashMap();
        map.put("code",code);
        map.put("msg",msg);
        map.put("data",data);
        return map;
    }

    public Map<String,Object> returnJson(int code, String msg, Map data){
        Map map=new HashMap();
        map.put("code",code);
        map.put("msg",msg);
        map.put("data",data);
        return map;
    }

    public Map<String,Object> returnJson(int code, String msg, int count,List<Layer> data){
        Map map=new HashMap();
        map.put("code",code);
        map.put("msg",msg);
        map.put("count",count);
        map.put("data",data);
        return map;
    }
}

Upload.java:

package com.example.sl.layer.util;

import org.springframework.web.multipart.MultipartFile;

import java.io.File;
import java.util.UUID;

//上傳
public class Upload {
    /**
     * 提取上傳方法為公共方法
     * @param uploadDir 上傳文件目錄
     * @param file 上傳對象
     * @throws Exception
     */
    public String executeUpload(String uploadDir,MultipartFile file) throws Exception
    {
        //文件后綴名
        String suffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
        //上傳文件名
        String filename = UUID.randomUUID() + suffix;
        //服務(wù)器端保存的文件對象
        File serverFile = new File(uploadDir + filename);
        //將上傳的文件寫入到服務(wù)器端文件內(nèi)
        file.transferTo(serverFile);

        return filename;
    }
}

順帶一提,這里返回給前端的數(shù)據(jù)有:fileName文件名還有dir文件路徑澜躺,之后做下載的時候會用到蝉稳。

Model層:
model包下的Layer.java實體類:

package com.example.sl.layer.model;

import com.fasterxml.jackson.annotation.JsonFormat;

import java.util.Date;

public class Layer {
    private String layerId;

    private String layerName;

    private String description;

    @JsonFormat(pattern="yyyy",timezone="GMT+8")
    private Date releaseTime;

    @JsonFormat(pattern="yyyy",timezone="GMT+8")
    private Date recordTime;

    private String fileName;

    public String getLayerId() {
        return layerId;
    }

    public void setLayerId(String layerId) {
        this.layerId = layerId == null ? null : layerId.trim();
    }

    public String getLayerName() {
        return layerName;
    }


    public void setLayerName(String layerName) {
        this.layerName = layerName == null ? null : layerName.trim();
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description == null ? null : description.trim();
    }

    public Date getReleaseTime() {
        return releaseTime;
    }

    @JsonFormat(pattern="yyyy",timezone="GMT+8")
    public void setReleaseTime(Date releaseTime) {
        this.releaseTime = releaseTime;
    }

    public Date getRecordTime() {
        return recordTime;
    }

    @JsonFormat(pattern="yyyy",timezone="GMT+8")
    public void setRecordTime(Date recordTime) {
        this.recordTime = recordTime;
    }

    public String getFileName() {
        return fileName;
    }

    public void setFileName(String fileName) {
        this.fileName = fileName == null ? null : fileName.trim();
    }
}

dao包:LayerMapper:

package com.example.sl.layer.dao;

import com.example.sl.layer.model.Layer;
import org.apache.ibatis.annotations.Param;

import java.util.Date;
import java.util.List;

public interface LayerMapper {
    int deleteByPrimaryKey(String layerId);

    int insert(Layer record);

    Layer selectByPrimaryKey(String layerId);

    List<Layer> selectAll();

    Layer selectByLayerName(String layerName);

    List<Layer> selectByDescription(String description);

    int updateByPrimaryKey(Layer record);

    List<Layer> selectByTime(@Param("time1")Date releaseTime1,@Param("time2") Date releaseTime2);
}

service包:
LayerService:

package com.example.sl.layer.service;

import com.example.sl.layer.model.Layer;

import java.util.Date;
import java.util.List;

public interface LayerService {
    public List<Layer> findAllLayers();

    public int InsertLayer(Layer layer);

    public int deleteLayer(String layerId);

    public Layer findByLayerName(String layerName);

    public List<Layer> findByDescription(String description);

    public List<Layer> findByTime(Date time1,Date time2);
}

LayerServiceImpl:

package com.example.sl.layer.service;

import com.example.sl.layer.dao.LayerMapper;
import com.example.sl.layer.model.Layer;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import javax.annotation.Resource;
import java.util.Date;
import java.util.List;

@Service("layerService")
@Transactional
public class LayerServiceImpl implements LayerService{

    @Resource
    private LayerMapper layerMapper;
    @Override
    public List<Layer> findAllLayers() {
        return layerMapper.selectAll();
    }

    @Override
    public int InsertLayer(Layer layer) {
        return layerMapper.insert(layer);
    }

    @Override
    public int deleteLayer(String layerId) {
        return layerMapper.deleteByPrimaryKey(layerId);
    }

    @Override
    public Layer findByLayerName(String layerName) {
        return layerMapper.selectByLayerName(layerName);
    }

    @Override
    public List<Layer> findByDescription(String description) {
        return layerMapper.selectByDescription(description);
    }

    @Override
    public List<Layer> findByTime(Date time1, Date time2) {
        return layerMapper.selectByTime(time1,time2);
    }
}

這里使用了jackson作date解析 所以實體類上有注解

5.效果一覽

以上就完成了上傳功能,讓我們來看看效果

上傳.gif

幫助到你了就給顆小????吧~

另附:
SpringBoot實現(xiàn)上傳下載(二)

項目僅供測試學(xué)習(xí)使用掘鄙,拒絕任何形式的商業(yè)用途耘戚,轉(zhuǎn)侵刪。
項目源碼關(guān)注公眾號Code In Java操漠,回復(fù)"SpringBoot上傳下載"即可獲取收津。除此之外,還有Java學(xué)習(xí)圖譜浊伙,數(shù)據(jù)結(jié)構(gòu)與算法資料等各種資料都可以在后臺獲取撞秋。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市嚣鄙,隨后出現(xiàn)的幾起案子吻贿,更是在濱河造成了極大的恐慌,老刑警劉巖哑子,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件舅列,死亡現(xiàn)場離奇詭異肌割,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)帐要,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進(jìn)店門把敞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人榨惠,你說我怎么就攤上這事奋早。” “怎么了赠橙?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵耽装,是天一觀的道長。 經(jīng)常有香客問我简烤,道長剂邮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任横侦,我火速辦了婚禮挥萌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘枉侧。我一直安慰自己引瀑,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布榨馁。 她就那樣靜靜地躺著憨栽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪翼虫。 梳的紋絲不亂的頭發(fā)上屑柔,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天,我揣著相機(jī)與錄音珍剑,去河邊找鬼掸宛。 笑死,一個胖子當(dāng)著我的面吹牛招拙,可吹牛的內(nèi)容都是我干的唧瘾。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼别凤,長吁一口氣:“原來是場噩夢啊……” “哼饰序!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起规哪,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤求豫,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體注祖,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡猾蒂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年均唉,在試婚紗的時候發(fā)現(xiàn)自己被綠了是晨。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡舔箭,死狀恐怖罩缴,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情层扶,我是刑警寧澤箫章,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站镜会,受9級特大地震影響檬寂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜戳表,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一桶至、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧匾旭,春花似錦镣屹、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至色瘩,卻和暖如春伪窖,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背居兆。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工覆山, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人史辙。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓汹买,卻偏偏與公主長得像,于是被迫代替她去往敵國和親聊倔。 傳聞我的和親對象是個殘疾皇子晦毙,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,033評論 2 355

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

  • 本文包括:1、文件上傳概述2耙蔑、利用 Commons-fileupload 組件實現(xiàn)文件上傳3见妒、核心API——Dis...
    廖少少閱讀 12,551評論 5 91
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)甸陌,斷路器须揣,智...
    卡卡羅2017閱讀 134,659評論 18 139
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,822評論 6 342
  • 我保持著頭幾本書的那種孤獨盐股。我隨身帶著它。我的寫作耻卡,我始終帶著它疯汁,不論我去哪里。去巴黎卵酪,去特魯維爾幌蚊。或者去紐約溃卡。 ...
    清清雅風(fēng)閱讀 260評論 0 1
  • 愛溢豆。太過沉重也不行,會壓得別人喘不過氣來瘸羡。人人都有自尊心漩仙,不希望一味的被保護(hù)。
    文森古堡閱讀 117評論 0 1