elementUI组件Upload + VUE 实现文件下载功能

本文详细介绍了如何在前端实现文件下载功能,包括点击下载按钮触发的方法,后端服务层的处理,以及前端如何接收并处理文件流。通过设置HTTP响应头和利用Blob对象,实现了文件的顺利下载。文件Hash用于验证文件唯一性,整个流程清晰易懂。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 实现如下功能

点击下载按钮下载当前文件,点击删除删除当前文件

2. 首先我们先看点击下载按钮触发的方法

//点击下载按钮获取当前行数据内容,跳转后端实现业务处理
            fileDownload(row) {
                download({
                    fileName: row.fileName,
                    fileUrl: row.fileUrl,
                    fileHash: row.fileHash
                })
            },

3. 后端service层入参需加一个HttpServletResponse对象

  public Result download(HttpServletResponse response, TestFile testFile) {
  //获取文件hash一样的文件(hash相同代表是同一个文件)
     List<TestFile > testFileHS = testFileMapper.selectList(new QueryWrapper<TestFile>()
                .eq("file_hash",testFile.getFileHash())
        // 获取testFileHS中的第一个对象并塞进file中
        File file = new File(testFileHS .get(0).getFileUrl());
        if (!file.exists()) {
            return ResultUtil.error(ResultCode.FAIL.getCode(), "当前附件本地文件不存在!");
        }
        //设置请求头
        response.setHeader("Content-Disposition", "attachment;filename=a.jpg");
        //设置类型
        response.setContentType("application/x-msdownload");
        //设置编码
        response.setCharacterEncoding("utf-8");
        FileInputStream bis;
        OutputStream os;
        try {
            //将file对象塞进一个输入流中
            bis = new FileInputStream(file);
            //创建一个byte对象
            byte[] buff = new byte[1024];
           //获取输出流
            os = response.getOutputStream();
            int i = 0;
            //当file对象的输入流没有结束的时候,通过输出流写出
            while ((i = bis.read(buff)) != -1) {
                os.write(buff, 0, i);
            }
            bis.close();
            os.close();
            return ResultUtil.success();
        } catch (IOException e) {
            return ResultUtil.error(ResultCode.FAIL.getCode(), "下载失败!");
        }
    }

4.后端结束之后返回前端处理文件流

/**
 1. 文件下载
 2. @param params
 */
export function download(params) {
    request({
        url: '/cxk/jntm',
        responseType: 'blob', // 表明返回服务器返回的数据类型
        method: 'post',
        data: params
    }).then(result => {
    //创建一个Blob对象接收后端传来的文件流
        const blob = new Blob([result], {
            type: 'application/octet-stream'
        })
        const downloadElement = document.createElement('a')
        // 创建下载的链接
        const href = window.URL.createObjectURL(blob) 
        downloadElement.href = href
        // 下载后文件名
        downloadElement.download = params.fileName 
        document.body.appendChild(downloadElement)
         // 点击下载
        downloadElement.click()
        // 下载完成移除元素
        document.body.removeChild(downloadElement) 
        // 释放掉blob对象
        window.URL.revokeObjectURL(href) 
    }).catch(err => {
            this.$message.error(err.message)
        })
}

好啦,到这里文件下载就结束了,另外fileHash这个东西是区别文件是否为同一个的,如果不做这个功能此步可以省略,觉得还不错的小伙伴可以点赞+收藏+转发,你的支持将会是我创作的动力,感谢有你!

你可以使用Vue.js和Element UI来实现前端界面,使用Spring Boot来处理后端逻辑来实现文件模板的上传和下载功能。 首先,你可以创建一个Vue组件来处理文件上传和下载的界面。可以使用Element UI中的Upload组件实现文件上传功能,使用Button组件实现文件下载功能。在上传组件中,你可以设置上传的文件类型和大小限制,并在上传成功后获取到文件的URL或者其他信息。 接下来,在后端使用Spring Boot来处理上传和下载的逻辑。你可以创建一个Controller来处理文件上传和下载的请求。在文件上传的方法中,你可以使用MultipartFile来接收上传的文件,并将其保存到服务器上的某个目录中。在文件下载的方法中,你可以根据传入的文件名或者其他标识,从服务器上读取相应的文件,并将其以流的形式返回给前端。 以下是一个简单的示例代码: 前端(Vue.js + Element UI): ```vue <template> <div> <el-upload class="upload-demo" action="/api/upload" :on-success="handleSuccess" :before-upload="beforeUpload" > <el-button type="primary">点击上传</el-button> </el-upload> <el-button type="primary" @click="downloadTemplate">下载模板</el-button> </div> </template> <script> export default { methods: { handleSuccess(response) { // 处理上传成功后的逻辑 console.log(response); }, beforeUpload(file) { // 设置上传文件的类型和大小限制 const fileType = file.type; const fileSize = file.size / 1024 / 1024; // MB const allowedTypes = ['application/pdf', 'application/msword', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document']; // 允许的文件类型 const maxFileSize = 10; // 允许的最大文件大小,单位:MB if (!allowedTypes.includes(fileType)) { this.$message.error('只能上传pdf、doc或docx格式的文件'); return false; } if (fileSize > maxFileSize) { this.$message.error(`文件大小超过了${maxFileSize}MB`); return false; } return true; }, downloadTemplate() { // 处理下载模板的逻辑 window.location.href = '/api/download'; }, }, }; </script> ``` 后端(Spring Boot): ```java @RestController @RequestMapping("/api") public class FileController { @PostMapping("/upload") public String uploadFile(@RequestParam("file") MultipartFile file) { // 处理文件上传逻辑 // 可以将上传的文件保存到服务器上的某个目录中 return "上传成功"; } @GetMapping("/download") public void downloadTemplate(HttpServletResponse response) { // 处理文件下载逻辑 // 根据文件名或者其他标识,从服务器上读取相应的文件,并将其以流的形式返回给前端 String fileName = "template.docx"; // 下载文件名 String filePath = "/path/to/template.docx"; // 文件在服务器上的路径 try { File file = new File(filePath); InputStream inputStream = new FileInputStream(file); response.setContentType("application/octet-stream"); response.setHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(fileName, "UTF-8")); IOUtils.copy(inputStream, response.getOutputStream()); response.flushBuffer(); } catch (Exception e) { e.printStackTrace(); } } } ``` 这是一个简单的示例,你可以根据自己的需求进行进一步的调整和优化。希望对你有帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值