为什么文本/纯下载图像类型



我有一个 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文件也被视为文本文件。

相关内容

  • 没有找到相关文章

最新更新