javascript-通过ajax打开FileStreamResult(作为下载文件)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript-通过ajax打开FileStreamResult(作为下载文件),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1343字,纯文字阅读大概需要2分钟。
内容图文
![javascript-通过ajax打开FileStreamResult(作为下载文件)](/upload/InfoBanner/zyjiaocheng/690/e01444042f6945de9ba901dc86987586.jpg)
是否可以使用ajax调用将FileStreamResult作为下载的文件打开?
控制器方式
public FileStreamResult DownloadPDF()
{
var stream = myHandler.getFileStream("myfile.pdf");
return File(stream, "application/pdf", "myfile.pdf"));
}
HTML代码
<a href="#" class="mydownload">Click Me</a>
<script type="text/javascript>
$("a.mydownload").click(function () {
$.ajax({
method: 'GET',
url: 'http://myserver/file/DownloadPDF',
success: function (data, status, jqXHR) {
var blob = new Blob([data], { type: "application/pdf" })
var url = window.URL.createObjectURL(blob);
var a = document.createElement("a");
document.body.appendChild(a);
a.href = url;
a.click();
}
});
});
</script>
在IE上运行时,我拒绝访问,但在Chrome上运行正常.但是,我确实得到了“空白” /无效的pdf.
解决方法:
使用responseHttp设置为“ blob”的XMLHttpRequest(),将下载属性添加到< a>元件
$("a.mydownload").click(function () {
var request = new XMLHttpRequest();
request.responseType = "blob";
request.open("GET", "http://myserver/file/DownloadPDF");
request.onload = function() {
var url = window.URL.createObjectURL(this.response);
var a = document.createElement("a");
document.body.appendChild(a);
a.href = url;
a.download = this.response.name || "download-" + $.now()
a.click();
}
request.send();
});
或者,您可以使用jquery-ajax-blob-arraybuffer.js.另请参见Add support for HTML5 XHR v2 with responseType set to ‘arraybuffer’ on $.ajax
内容总结
以上是互联网集市为您收集整理的javascript-通过ajax打开FileStreamResult(作为下载文件)全部内容,希望文章能够帮你解决javascript-通过ajax打开FileStreamResult(作为下载文件)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。