首页 > 解决方案 > 如何从 JSON 响应解码客户端的 Base64 文件?

问题描述

我有一个在服务器端呈现文件的应用程序。我通过 json 将它作为“base64”字符串传递。我需要在客户端解码和下载文件。我以简化的形式呈现了代码,留下了与问题相关的内容。

这是快递服务器上的路线:

let xlsx = require('node-xlsx').default;
const express = require('express');
const router = express.Router();

router.get('/', (req, res) => {
  const data = [[1, 2, 3], ['a', 'b', 'c']];
  var buffer = xlsx.build([{ name: "mySheetName", data: data }])
    .toString('base64');
  res.json(buffer);
});

module.exports = router;

客户端上的 React 组件:

import React, { useEffect } from 'react';
import axios from 'axios';

const First = () => {
  useEffect(() => {
    axios({
      url: 'http://localhost:5000/excel',
      method: 'GET',
      responseType: 'blob',
    }).then(res => {
      const url = window.URL.createObjectURL(new Blob([res.data]));
      const link = document.createElement('a');
      link.href = url;
      link.setAttribute('download', 'data.xlsx');
      document.body.appendChild(link);
      link.click();
    });
  }, []);
  return (
    <div>
      <h3>First page</h3>
      <hr className="gold" />
    </div>
  );
};

export default First;

问候。

标签: javascriptnode.jsjsonexpressbase64

解决方案


采用atob

查看快速示例

let myData = "YQ=="


console.log(atob(myData)); // a


推荐阅读