基于ASP.NET Webapi和ajax技术且兼容Chrome、Firefox和IE浏览器的Excel文件下载方法

本文介绍了一个使用ASP.NET MVC、WebAPI、jQuery、Ajax和EasyUI构建的高速公路大数据分析网站项目。在项目中,通过NPOI生成Excel报表并转化为base64字符串,通过WebAPI返回。尽管Chrome和Firefox能够正常下载,但在IE浏览器中遇到问题。为了解决IE的兼容性问题,需要进行两次HTTP请求:首次请求保存文件流到缓存,第二次请求使用模拟的<a>标签下载。最终成功实现了三大浏览器的文件下载兼容。
摘要由CSDN通过智能技术生成

这个假期都在做一个综合ASP.NET MVC、Webapi、jquery、ajax、easyui等技术和框架的高速公路大数据分析网站项目。系统用json做前后端通信的数据格式,后端主要用Webapi处理业务逻辑,并返回一个定制的消息对象,前端就是jquery、ajax和easyui等呈现和相关处理。

前面的文件上传、参数传递、CRUD操作、数据集合返回给easyui等都做得十分顺利。最后,要输出报表了。使用NPOI组件在后端生成一个Excel报表,然后像image处理一样转换成base64字符串格式,通过Webapi返回给前端浏览器。Chrome和Firefox均能很好地支持直接在浏览器里打开下载窗口,见如下代码:

    function DownloadFile(xlsBase64)  
    {
        if (!document.getElementById("dwnf"))
        {
            $(document.body).append('<a href="#" id="dwnf" style="display: none"></a>');
        }

        var reportName = $('#ReportNames').val();
        var fileName =  reportName + '_' + GetPeriodNo() + '.xls';
        var url = '
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值