java调用第三方接口获取文件,前端axios下载流文件

1.Java调用第三方接口获取文件流

public void downloadResultFile(HttpServletResponse response, HttpServletRequest request) throws Exception {
        SymmetricCrypto aes = new SymmetricCrypto(SymmetricAlgorithm.AES, AesKey.getBytes());
        String id = request.getParameter("id");//"IT7pPVCdYY%2BBTwmTU4%2B35A%3D%3D";
        String token = request.getParameter("token");
        String timeStamp = request.getParameter("timeStamp");
        URL url = new URL('xxxx');//接口地址
        HttpURLConnection conn = (HttpURLConnection) url.openConnection();
        final ByteArrayOutputStream output = new ByteArrayOutputStream();
        IOUtils.copy(conn.getInputStream(), output);
        response.reset();
        response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
        response.setHeader("Content-Disposition", conn.getHeaderFields().get("Content-Disposition").get(0));
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setContentType("application/x-download");
        byte[] buff = new byte[1024];
        OutputStream os = response.getOutputStream();
        BufferedInputStream bis = new BufferedInputStream(new ByteArrayInputStream(output.toByteArray()));
        int i;
        while ((i = bis.read(buff)) != -1) {

            os.write(buff, 0, i);

            os.flush();

        }
        bis.close();
        os.close();
        conn.disconnect();
    }

2.前端调用java接口 下载文件流

 downloadResultFileApi({
        timeStamp: AES.encrypt(time, passWord),
        token: "c9z9jOEppZu2LL7pfaNarA==",
        id: e.imgId,
      }).then((res) => {
        var blob = new Blob([res.data], {type: "image/png"});
        var downloadElement = document.createElement("a");
        var href = window.URL.createObjectURL(blob); // 创建下载的链接
        downloadElement.href = href;
        downloadElement.download =
        decodeURI(res.headers["content-disposition"].split("filename=")[1]) ||""; // 下载后文件名
        document.body.appendChild(downloadElement);
        downloadElement.click(); // 点击下载
        document.body.removeChild(downloadElement); // 下载完成移除元素
        window.URL.revokeObjectURL(href); // 释放掉blob对象
      });

注:
blob文件流 type类型 需与文件类型一致;
export function downloadResultFileApi(data){

return service.request({
    method: "get",
    url: '/output/downloadResultFile',
    params:data,
    responseType: 'blob'
})

}
axios请求设置responseType:‘blob’

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值