gpt4 book ai didi

javascript - 如何打开 POST 生成的 CSV 文件

转载 作者:搜寻专家 更新时间:2023-10-31 21:46:25 27 4
gpt4 key购买 nike

我正在尝试实现这些看似简单的要求,但找不到方法:

  • 使用 Angular JS 的单页应用
  • REST(ish) 后端
  • 通过 POST 请求公开后端资源
  • 在请求正文中以 JSON 形式传递的资源参数
  • 资源生成 CSV 文件
  • 当用户点击按钮时,生成请求正文中包含正确 JSON 参数的请求,发送请求,并允许用户将响应下载为文件(提示浏览器的“打开/另存为”对话框)

问题主要是,如何将JSON作为request body传递?最常见的技术似乎是隐藏的 HTML 表单来触发下载,但 HTML 表单无法在正文中发送 JSON 数据。而且我找不到任何方法来使用 XMLHttpRequest 触发下载对话框...

有什么想法吗?

我指定了 Angular,但也非常欢迎任何通用的 JS 解决方案!

最佳答案

我终于找到了一个可以满足我所有要求的解决方案,并且可以在 IE11、FF 和 Chrome 中运行(并且在 Safari 中降低了某种程度的 OK...)。

想法是创建一个包含响应数据的 Blob 对象,然后强制浏览器将其作为文件打开。 IE(专有 API)和 Chrome/FF(使用链接元素)略有不同。

下面是实现,作为一个小的 Angular 服务:

myApp.factory('Download', [function() {
return {
openAsFile : function(response){

// parse content type header
var contentTypeStr = response.headers('Content-Type');
var tokens = contentTypeStr.split('/');
var subtype = tokens[1].split(';')[0];
var contentType = {
type : tokens[0],
subtype : subtype
};

// parse content disposition header, attempt to get file name
var contentDispStr = response.headers('Content-Disposition');
var proposedFileName = contentDispStr ? contentDispStr.split('"')[1] : 'data.'+contentType.subtype;

// build blob containing response data
var blob = new Blob([response.data], {type : contentTypeStr});

if (typeof window.navigator.msSaveBlob !== 'undefined'){
// IE : use proprietary API
window.navigator.msSaveBlob(blob, proposedFileName);
}else{
var downloadUrl = URL.createObjectURL(blob);

// build and open link - use HTML5 a[download] attribute to specify filename
var a = document.createElement("a");

// safari doesn't support this yet
if (typeof a.download === 'undefined') {
window.open(downloadUrl);
}

var link = document.createElement('a');
link.href = downloadUrl;
link.download = proposedFileName;
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
}
}
}
}]);

响应参数需要一个 $http 响应对象。以下是使用 POST 请求的示例:

$http.post(url, {property : 'value'},  {responseType: 'blob'}).then(function(response){
Download.openAsFile(response);
});

注意 responseType 参数。如果没有这个,我的 CSV 数据将被读取为文本并以 UTF-8(或 16)格式存储在内存中,随后文件以相同的编码保存,导致 Excel 无法识别 éè 等特殊字符。由于我的 CSV旨在由 Excel 打开,服务器将它们编码为 Windows 1252,我想保持这种状态。将 responseType 参数设置为 blob 可实现此目的。

免责声明:它适用于任何文件类型。但我只用 CSV 文件测试过它!二进制文件的行为可能会有所不同!

关于javascript - 如何打开 POST 生成的 CSV 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39078655/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com