我有一个 asp.net 的Web服务,如下所示,用于返回base 64:
[WebMethod]
public string DownloadMediaFiles(string filePathUri, string fileName) {
try {
using(WebClient client = new WebClient()) {
Byte[] bytes = client.DownloadData(filePathUri);
string base64String = Convert.ToBase64String(bytes);
return base64String;
}
} catch (Exception ex) {
throw ex;
}
}
下面是我的 ajax 调用:
$.ajax({
type: 'POST',
url: "Path To My Webservice" + "DownloadMediaFiles",
data: {
filePathUri: filePath,
fileName: 'a.txt'
},
contentType: 'application/json;charset=uf=8',
dataType: 'json',
success: function(data) {
var element = document.createElement('a');
element.setAttribute('href', 'data:text/plain;base64,' +
data.d);
element.setAttribute('download', 'a.txt');
element.style.display = 'none';
document.body.appendChild(element);
element.click();
document.body.removeChild(element);
},
error: function() {
alert("error");
}
});
它工作正常并下载文本文件,因为我已将 dataUri 设置为 data:text/plain;base64,但是当我将文件名作为图像文件"pointing_2017_07_17_03_17_60.png"时,它也在下载,尽管 datauri 设置为文本/纯文本。
以下是我对txt文件和图像文件的html标记:
txt 文件:
<a href="data:text/plain;base64,certainbase64data" download="a.txt" style="display: none;"></a>
图像文件:
<a href="data:text/plain;base64,certainbase64data" download="pointing_2017_07_17_03_17_60.png" style="display: none;"></a>
href="data:text/plain;base64
此属性正在下载文本和图像文件。
我想知道为什么文本/纯文本同时下载图像和文本文件?
text/plain
是文本文件的默认值。即使它真的意味着未知的文本文件,浏览器也认为他们可以显示它。
请注意,文本/纯文本并不意味着任何类型的文本数据。如果他们 期望特定类型的文本数据,他们可能不会考虑 这是一场比赛。特别是如果他们从 元素声明 CSS 文件,它们不会将其识别为 有效的 CSS 文件(如果以文本/纯文本显示(。CSS MIME 类型 必须使用文本/CSS。
有关更多详细信息:MIME 类型
因此,您的pointing_2017_07_17_03_17_60.png文件也被视为文本文件。