后端接口返回二进制文件,前端 window.opent预览展示

详细步骤

1.修改 PreviewApi 函数:

  • 设置 responseType 为 'arraybuffer',以接收二进制数据。
javascript 复制代码
export const PreviewApi = (data) => request({
  method: 'post',
  url: '/dev-api/preview',
  responseType: 'arraybuffer',
  data
});

3.处理响应:

  • 使用 new Uint8Array(response.data) 将 ArrayBuffer 转换为 Uint8Array。
  • 使用 Blob 构造函数将 Uint8Array 转换为 Blob 对象。
  • 使用 URL.createObjectURL 方法生成 Blob URL。
  • 使用 window.open 方法在新窗口中打开生成的 Blob URL。
javascript 复制代码
<template>
  <div>
    <button @click="onPreview(row)">预览 PDF</button>
  </div>
</template>

<script>
import { ldjtPreviewApi } from '@/api/your-api-file'; // 引入你的 API 文件

export default {
  data() {
    return {
      row: { qqlsh: 'example_qqlsh' } // 示例数据,实际使用时从父组件或其他地方获取
    };
  },
  methods: {
    onPreview(row) {
      ldjtPreviewApi({ qqlsh: row.qqlsh }).then((response) => {
        if (response.status === 200) {
          const binaryData = new Uint8Array(response.data);
          const url = this.binaryToPdfUrl(binaryData);
          console.log('Generated URL:', url);
          window.open(url);
        } else {
          this.$message({
            message: '请求失败',
            type: 'error'
          });
        }
      }).catch((error) => {
        this.$message({
          message: error.message || '请求出错',
          type: 'error'
        });
      })
    },
    binaryToPdfUrl(binaryData) {
      const blob = new Blob([binaryData], { type: 'application/pdf' });
      const url = URL.createObjectURL(blob);
      return url;
    }
  }
};
</script>

<style scoped>
/* 你可以在这里添加一些样式 */
</style>

手动验证二进制数据

你可以将二进制数据保存为文件,手动打开验证 PDF 文件是否有效。以下是一个示例代码:

javascript 复制代码
function binaryToPdfFile(binaryData, filename) {
  const blob = new Blob([binaryData], { type: 'application/pdf' });

  // 创建一个临时的下载链接
  const link = document.createElement('a');
  link.href = URL.createObjectURL(blob);
  link.download = filename;
  link.click();
}

// 调用函数,将二进制数据保存为 PDF 文件
binaryToPdfFile(new Uint8Array(response.data), 'test.pdf');
相关推荐
c_zyer7 分钟前
使用 nvm 管理 Node.js 和 npm 版本
前端·npm·node.js
布Coder23 分钟前
前端 vue + element-ui 框架从 0 - 1 搭建
前端·javascript·vue.js
i_am_a_div_日积月累_28 分钟前
Element Plus 取消el-form-item点击触发组件,改为原生表单控件
前端·vue.js·elementui
集成显卡32 分钟前
网页 H5 微应用接入钉钉自动登录
前端·后端·钉钉
paintstar34 分钟前
el-scrollbar 获取滚动条高度 并将滚动条保持在低端
前端·学习·vue·css3
天天进步20151 小时前
前端测试策略:单元测试到 E2E 测试
前端·单元测试
多啦爱梦的梦想2 小时前
项目中把webpack 打包改为vite 打包
前端·webpack
小刘不知道叫啥2 小时前
简单说一下 Webpack分包
前端·javascript·webpack·node.js
Dontla2 小时前
《黑马前端ajax+node.js+webpack+git教程》(笔记)——node.js教程+webpack教程(nodejs教程)
前端·ajax·node.js
繁依Fanyi3 小时前
项目记录:「五秒反应挑战」小游戏的开发全过程
前端·codebuddy首席试玩官