vue + element Upload + axios文件上傳

項目開發采用前后端分離,在開發中發現需要開發附件上傳功能,遇到的一些問題,做一些總結和記錄
整個文件上傳邏輯是:
1 前端文件上傳前,先使用插件計算文件的唯一MD5值
2 將MD5值上傳到服務器,后端進行校驗是否存儲有相同的MD5值文件
3 如果不存在,上傳文件到后端服務器進行存儲;如果存在,則前端不在重復提交文件

使用MD5 優勢

1 前端生成文件唯一MD5,減輕后端服務器壓力
2 文件的唯一性標志,減小ftp服務器存放重復文件概率(重復率為零?待測試)

使用MD5 缺點

1 上傳一個文件需要2個http請求,如果文件已經存在,則為一次請求(1:上傳MD5驗證文件是否已經存在 2:不存在則再次上傳文件),如果網絡環境差,影響操作體驗

優化方案: 文件和文件MD5同時傳輸到后端進行處理

遇到問題

1 前端使用element Upload 組件如何自定義上傳文件
2 前端如何 hash 生成文件 MD5
3 前端使用 axios post 請求上傳文件到服務器
4 后端代碼(java)如何接收前端上傳的文件

前端架構: vue ,element, axios

后端架構:java, springBoot

解決步驟1:

配置 Upload 組件 http-request 屬性 ,自定義http上傳

:http-request = "customUpload"

核心代碼代碼:

<el-upload
  class="upload-demo"
  ref="upload"
  :multiple="false"
  action="http://127.0.0.1:8080/docmanager/upload"
  :http-request = "customUpload"
  :on-remove="handleRemove"
  :on-change="handleChange"
  :file-list="fileList"
  :auto-upload="true">
  <el-button slot="trigger" size="small" type="primary">選取文件</el-button>
  <el-button style="margin-left: 10px;" size="small" type="success" @click="submitUpload">上傳到服務器</el-button>
  <div slot="tip" class="el-upload__tip">只能上傳jpg/png文件,且不超過500kb</div>
</el-upload>
customUpload(file) {
  // this.generatorFileMd5(file.file)
  // 自定義上傳
  fileUpload(file).then(response => {
    console.log(response)
  })
}

解決步驟2:

使用hash 生成 MD5

安裝依賴包:spark-md5 spark-md5

npm install --save spark-md5

核心代碼:

generatorFileMd5(file) {
  /**
    * 生成MD5
    */
  let blobSlice = File.prototype.slice || File.prototype.mozSlice || File.prototype.webkitSlice
    // file = this.files[0],
  let chunkSize = 2097152                           // Read in chunks of 2MB
  let chunks = Math.ceil(file.size / chunkSize)
  let currentChunk = 0
  let spark = new SparkMD5.ArrayBuffer()
  let fileReader = new FileReader()
  fileReader.onload = function (e) {
      // console.log('read chunk nr', currentChunk + 1, 'of', chunks)
      spark.append(e.target.result)                  // Append array buffer
      currentChunk++;

      if (currentChunk < chunks) {
          loadNext();
      } else {
          // console.info('computed hash', spark.end())  // spark.end(): 文件 MD5值生成完成
          console.log(spark.end())
      }
  };

  fileReader.onerror = function () {
      console.warn('fileReader.onerror is error')
  };

  function loadNext() {
      var start = currentChunk * chunkSize,
          end = ((start + chunkSize) >= file.size) ? file.size : start + chunkSize;

      fileReader.readAsArrayBuffer(blobSlice.call(file, start, end))
  }

  loadNext()
}

解決步驟3:

使用axios上傳文件

/**
 * 文件上傳
 */
export function fileUpload(fileobj) {
  let param = new FormData()
  param.append('files',fileobj.file)
  return request({
    method: 'post',
    url: '/docmanager/upload',
    headers: {'Content-Type':'multipart/form-data'},
    data: param
  })
}

解決步驟4:

后端接收前端文件

@PostMapping("/upload")
    @JsonBody
    public List<DocForm> upload(MultipartFile[] files) throws Exception {
        List<DocForm> rs = new ArrayList<DocForm>();
        for (MultipartFile file : files) {
            // ... 處理文件儲存邏輯
        }
        return rs;
    }
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,791評論 6 545
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,795評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,943評論 0 384
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 64,057評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,773評論 6 414
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,106評論 1 330
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,082評論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,282評論 0 291
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,793評論 1 338
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,507評論 3 361
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,741評論 1 375
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,220評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,929評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,325評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,661評論 1 296
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,482評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,702評論 2 380