post下载、返回Base64下载

1.大多数时候我们都是通过get实现下载,那如果需要通过post实现呢?下面就来记录一下post实现下载的代码:

//url 请求地址
//obj 传入的参数
downloadExcel(url, obj) {
        let tempForm = document.createElement('form');
        // var token = window.token || ''
        // if (url && token) {
        //     if (url.indexOf('?') !== -1) {
        //         url = url + '&token=' + token;
        //     } else {
        //         url = url + '?token=' + token;
        //     }
        // }
        tempForm.action = url;
        tempForm.method = 'post';
        tempForm.onsubmit = "return false";
        tempForm.style.display = 'none';
        for (let st in obj) {
            if (obj.hasOwnProperty(st)) {
                let opt = document.createElement('textarea');
                opt.name = st;
                opt.value = obj[st];
                tempForm.appendChild(opt);
            }
        }
        document.body.appendChild(tempForm);
        tempForm.submit();
        return tempForm;
    }

2.后端返回的Base64位如何转换

// base64转换
export function base64ToArrayBuffer(base64) {
  var binaryString = window.atob(base64);
  var binaryLen = binaryString.length;
  var bytes = new Uint8Array(binaryLen);
  for (var i = 0; i < binaryLen; i++) {
    var ascii = binaryString.charCodeAt(i);
    bytes[i] = ascii;
  }
  return bytes;
}

export function saveByteArray(reportName, byte) {
  const link = document.createElement("a"); // 创建a标签
  const blob = new Blob([byte], {
    type: "application/vnd.ms-excel;charset=utf-8",
  }); // response就是接口返回的文件流
  const objectUrl = URL.createObjectURL(blob);
  link.href = objectUrl;
  link.download = reportName;
  link.click(); // 下载文件
  URL.revokeObjectURL(objectUrl);
}
// 应用
const sampleArr = base64ToArrayBuffer(this.failData.fileByte); // 这里先调用base64ToArrayBuffer将base64转为二进制流
saveByteArray(文件名称, sampleArr); // 然后将文件名称和数据流直接给到saveByteArray方法进行下载
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
ThinkPHP 是一个开源的 PHP 框架,它简化了 PHP 开发者的开发流程。当你需要在 ThinkPHP 中处理用户上传 base64 编码的图片时,你可以按照以下步骤操作: 1. 首先,接收前端提交的 base64 图片数据。这通常发生在控制器(Controller)的方法中,例如 `uploadAction`: ```php public function uploadAction(Request $request) { $base64Data = $request->post('image_base64'); // 其他验证和处理 } ``` 2. 解码 base64 数据为二进制流: ```php $data = base64_decode($base64Data); ``` 3. 创建临时文件并保存解码后的图片: ```php $tempFile = tempnam(THINK_ROOT . 'public/upload', 'img_'); // 假设你有一个公共文件夹 upload file_put_contents($tempFile, $data); ``` 4. 使用 ThinkPHP 的上传功能(如 `upload` 函数)将图片移动到服务器上指定的目录,并获取新的文件名或路径。这里假设你使用的是官方的上传配置: ```php $upload = new \Think\Upload(); $upload->isCheck(false); // 关闭验证,因为我们已经有了 base64 数据 $upload->savePath = '/path/to/your/upload/directory'; // 设置保存路径 $info = $upload->upload($tempFile); ``` 5. 如果上传成功,`$info` 将包含文件信息,包括新路径。你可以像这样获取路径: ```php $filePath = $info['savepath'] . '/' . $info['name']; ``` 6. 清理临时文件(如果需要): ```php unlink($tempFile); ``` 7. 返回上传路径给前端: ```php $response['url'] = $filePath; echo json_encode($response); ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值