vue2文件上传与下载

1.文件上传 

html部分使用element上传组件

      <el-upload
        class="upload-demo"
        :action="importUrl" //上传路径,如http://192.168.18.231:9528/xxxx
        multiple
        :show-file-list="true" //是否真实文件列表
        :on-success="handleSuccess" //上传成功触发
        :on-error="handleError"  //上传失败触发
        :data="importUscc" //对象类型  额外的参数,如{ uscc: this.formData.uscc }
        :auto-upload="false" //是否在选取文件后立即进行上传(false为不立即上传)
        :on-change="changeList" //文件状态改变时的钩子,添加文件、上传成功和上传失败时都会触发
      >
        <el-button size="small" type="primary">点击上传</el-button>
        
      </el-upload>
      <el-button type="text" @click="downloadFile">点击下载</el-button>
      <span slot="footer" class="dialog-footer">
        <el-button @click="importDialogVisible = false">取消</el-button>
        <el-button type="primary" @click="importByCond">确定</el-button>
      </span>

js部分

若文件立即上传,auto-upload为true,在选择好文件点击打开后便可自动上传

若文件不立刻上传,auto-upload为false,则后续触发上传函数如下

 // 上传文件
    importByCond() {
      //参数,注意请求头应为文件格式
      const obj = {
        uscc: this.formData.uscc,
        file: this.file
      }
      batchImport(obj).then(res => {
        if (res.state === 200) {
          this.$message({
            message: '文件上传成功',
            type: 'success'
          })
          // 刷新页面
          this.getListFileds()
        } else {
          this.$message({
            message: '文件上传失败',
            type: 'error'
          })
        }
      })
    },

注:请求头转为文件格式

// 导入文件
export function batchImport(data) {
  return request({
    url: '/wasteGasMonitor/batchImport',
    method: 'post',
    data,
    //请求头格式转成文件格式
    headers: {
      'Content-Type': 'multipart/form-data'
    }
  })
}

2.文件下载

触发函数downloadFile

如果后端提供的是下载地址

 // 下载文件
    downloadFile() {
      // 文件的URL地址
      const fileUrl = 'http://xxx.com/template/file/download?fileName=文件名.xlsx'
      // 下载文件
      window.open(fileUrl)
      this.importDialogVisible = false
    },

如果后端提供的接口

// 下载文件

export function downloadImport(params) {  

  return request({

    url: '/masterdata/v1/template/file/xxxxx',

    method: 'get',

    params,

    responseType: 'blob',

    headers: {

      'Content-Type': 'application/json'

    }

  })

}

 函数

   // 触发了下载文件的函数

    downloadFile() {

      downloadImport({ fileName: '文件名.xlsx' }).then(res => {

        const link = document.createElement('a')

        link.download = '文件名.xlsx'

        link.href = window.URL.createObjectURL(res)

        link.click()

        window.URL.revokeObjectURL(link.href)

      })

    },

效果

 

你好!关于Spring Boot和Vue文件上传下载的问题,我可以为你提供一些解答。 在Spring Boot中,你可以使用Spring MVC的文件上传功能来处理文件上传。首先,你需要在Spring Boot项目中配置一个文件上传的Bean。可以使用`MultipartResolver`接口来实现文件上传功能。下面是一个示例代码: ```java @Configuration public class WebConfig implements WebMvcConfigurer { @Bean public MultipartResolver multipartResolver() { return new StandardServletMultipartResolver(); } } ``` 接下来,你可以创建一个Controller来处理文件上传请求。你可以使用`@RequestParam`注解来接收上传的文件。以下是一个简单的上传文件的示例: ```java @RestController public class FileController { @PostMapping("/upload") public ResponseEntity<String> uploadFile(@RequestParam("file") MultipartFile file) { // 处理文件上传逻辑 // 返回上传成功的消息 return ResponseEntity.ok("文件上传成功!"); } } ``` 在Vue中,你可以使用`axios`库来发送文件上传请求。以下是一个简单的文件上传的示例代码: ```javascript <template> <div> <input type="file" ref="fileInput" @change="uploadFile"> </div> </template> <script> import axios from 'axios'; export default { methods: { uploadFile() { const file = this.$refs.fileInput.files[0]; const formData = new FormData(); formData.append('file', file); axios.post('/upload', formData) .then(response => { // 处理上传成功的逻辑 console.log(response.data); }) .catch(error => { // 处理上传失败的逻辑 console.error(error); }); } } } </script> ``` 至于文件下载,你可以在Spring Boot中创建一个Controller来处理下载请求。你可以使用`ResponseEntity`来返回文件内容和正确的HTTP头。以下是一个简单的文件下载的示例: ```java @RestController public class FileController { @GetMapping("/download") public ResponseEntity<Resource> downloadFile() throws IOException { // 加载文件资源 Resource fileResource = new ClassPathResource("path/to/file.pdf"); // 设置HTTP头 HttpHeaders headers = new HttpHeaders(); headers.add(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=file.pdf"); return ResponseEntity.ok() .headers(headers) .body(fileResource); } } ``` 在Vue中,你可以使用`window.open`方法来下载文件。以下是一个简单的文件下载的示例代码: ```javascript <template> <div> <button @click="downloadFile">下载文件</button> </div> </template> <script> export default { methods: { downloadFile() { const downloadURL = '/download'; window.open(downloadURL, '_blank'); } } } </script> ``` 希望以上信息能够帮助到你!如果有任何问题,请随时问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值