Springboot + Vue 上传Word、PDF文档并保留内部格式

因为业务需求,上传Word文件需要编辑,但如何使用Blob方式,在数据库里存文件,就会造成格式消失。所以修改思路:上传文件到服务器本地,保证数据存储的完整性。

前端

html 复制代码
              <el-upload class="upload-demo" :action="item.fileUploadUrl" :show-file-list="false" :limit="1" :multiple="false" :auto-upload="true" :accept="item.accept" :before-upload="beforeUpload"
                :headers="item.uploadHeaders" :data="item.uploadData">上传
              </el-upload></el-button>
              
javascript 复制代码
     fileActionList: [
        {
          width: 60,
          name: "合同文件",
          fileUploadUrl: "*************/importContract",
          uploadData: {},
          uploadHeaders: {},
          accept: ".doc,.docx,.pdf",
        },
      ],



    beforeUpload(file, fileList) {
      let promise = new Promise((resolve) => {
        this.$nextTick(function () {
          resolve(true);
        });
      });
      this.$message.success("上传成功");

      return promise;
    },
        // 文件上传操作
    handleImport(row) {
      this.fileActionList[0].uploadData = {
        id: row.id,
      };
      this.fileActionList[0].uploadHeaders = {
        Authorization: Cookie.get("*******"),
      };
    },

就是常规的传文件

后端

java 复制代码
    @ApiOperation("导入合同文件")
    @PostMapping("importContract")
    public Result importData(@RequestParam(value="file") MultipartFile file, @RequestParam(value="id") Long id) throws Exception {
        return projectService.importData(file, id);
    }
        @Override
    public Result importData(MultipartFile file, Long id) throws Exception {
        //获取文件名
        InputStream path = null;
        FileInputStream fis = null;
        FileOutputStream fos = null;
        try {
            path = file.getInputStream();
            fis = (FileInputStream) path;
            File dir = new File("file/project");
            if (!dir.exists()) {
                dir.mkdirs();
            }
            String filePath = "file/project/" + id + "_" + System.currentTimeMillis() + "_" + file.getOriginalFilename();
            fos = new FileOutputStream(filePath);
            int readlen = 0;
            //字节数组,一次读取8个字节
            byte[] buf = new byte[8];
            while ((readlen = fis.read(buf)) != -1) {
                fos.write(buf, 0, readlen);
            }
            Project project = projectRepo.getById(id);
            project.setContactFile(filePath);
            projectRepo.save(project);
        } catch (IOException e) {
            log.error("" + e);
        } finally {
            path.close();
            fis.close();
            fos.close();
        }
        return Result.success("上传成功");
    }

这此采用的思路就是 把文件读取后,写入相对路径,考虑到文件业务误传,服务器源文件不删除,通过时间戳保证唯一性。存到服务器本地。

可以看到,最后格式都保留了下来

![在这里插入图片描述](https://img-blog.csdnimg.cn/6c7c61ef8085404ea23c4be0ca6c6f19.png![在这里插入图片描述](https://file.jishuzhan.net/article/1681602352328478722/cd8d0d203ebd497582691154d2df79e4.png)

相关推荐
会跑的葫芦怪5 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
pas1368 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
军军君019 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
过期动态11 小时前
Java开发中的@EnableWebMvc注解和WebMvcConfigurer接口
java·开发语言·spring boot·spring·tomcat·maven·idea
Hi_kenyon11 小时前
理解vue中的ref
前端·javascript·vue.js
我爱娃哈哈12 小时前
SpringBoot + Flowable + 自定义节点:可视化工作流引擎,支持请假、报销、审批全场景
java·spring boot·后端
韩师学子--小倪13 小时前
SpringBoot 优雅停服
spring boot·tomcat
思想在飞肢体在追14 小时前
Springboot项目配置Nacos
java·spring boot·后端·nacos
毎天要喝八杯水15 小时前
搭建vue前端后端环境
前端·javascript·vue.js
JavaGuide16 小时前
推荐一个基于 Spring Boot 4.0 + Java 21 + Spring AI 2.0 的大模型项目!
java·spring boot·spring