国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

vue使用el-upload上傳文件及Feign服務間傳遞文件的方法

2024-05-06 15:41:38
字體:
來源:轉載
供稿:網友

一、前端代碼

<el-upload class="step_content" drag         action="string"         ref="upload"         :multiple="false"         :http-request="createAppVersion"         :data="appVersion"         :auto-upload="false"         :limit="1"         :on-change="onFileUploadChange"         :on-remove="onFileRemove">    <i class="el-icon-upload"></i>    <div class="el-upload__text">將文件拖到此處,或<em>點擊上傳</em></div></el-upload> <div class="mgt30">    <el-button v-show="createAppVisible" :disabled="createAppDisable" type="primary" class="mgt30"          @click="onSubmitClick">立即創建    </el-button> </div>.... onSubmitClick() {    this.$refs.upload.submit();   },   createAppVersion(param) {    this.globalLoading = true;    const formData = new FormData();    formData.append('file', param.file);    formData.append('appVersion', JSON.stringify(this.appVersion));    addAppVersionApi(formData).then(res => {     this.globalLoading = false;     this.$message({message: '創建APP VERION 成功', type: 'success'});     this.uploadFinish();    }).catch(reason => {     this.globalLoading = false;     this.showDialog(reason);    })   },

說明:

    el-upload 的 ref="upload" 給這個組件起個變量名,以便 js邏輯代碼可以引用 http-request="createAppVersion" el-upload 上傳使使用自定義的方法 :data="appVersion" 上傳時提交的表單數據 onSubmitClick 方法中會調用el-upload.submit()方法,進而調用createAppVersion()方法 組成表單參數,取得上傳的file 和 其它參數
const formData = new FormData();formData.append('file', param.file);formData.append('appVersion', JSON.stringify(this.appVersion));

6.addAppVersionApi 最終會調用下面的方法,其中formData就是param, 請求需要加header: 'Content-Type': 'multipart/form-data'

 function httpPostMutipartFileAsyn(url, param) { return new Promise((resolve, reject) => {  request({   url: url,   headers: {    'Content-Type': 'multipart/form-data'   },   method: 'post',   data: param  }).then(response => {   if (response.data.status.code === 0) {    resolve(response.data)   } else {    reject(response.data.status)   }  }).catch(response => {   reject(response)  }) })}

二、后端代碼

1.后端controller接口

@PostMapping("/version/add")  public RestResult addAppVersion(@RequestParam("appVersion") String appVersion,                  @RequestParam("file") MultipartFile multipartFile) {    ....        return new RestResult();  }

三、Feign 實現服務間傳遞MultipartFile參數

Controller的addAppVersion()接口,收到上傳的文件后,需要通過Http調用遠程接口,將文件上傳到資源服務。一開始嘗試使用OKHttp 和 RestTemplate 實現,但是這兩種方法都必須將文件先保存,無法直接傳遞MultipartFile參數,然后才能通過OKHttp 和 RestTemplate提供的相關接口去實現。 本著不想在本地保存臨時文件的,找到了通過Feign解決的一種方式

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 谢通门县| 阳春市| 南京市| 兴宁市| 正镶白旗| 辽宁省| 宿迁市| 博兴县| 务川| 衡阳县| 济南市| 平果县| 富蕴县| 乃东县| 乌拉特中旗| 乌兰浩特市| 镇雄县| 台东市| 永昌县| 枣阳市| 怀来县| 锦屏县| 贵溪市| 土默特左旗| 鹤庆县| 赤峰市| 秭归县| 肃南| 连江县| 玛多县| 兰西县| 内乡县| 岑溪市| 广安市| 贵定县| 响水县| 靖远县| 固阳县| 锦州市| 东乌珠穆沁旗| 临夏市|