首先,目前我是在Json里面使用的,然后关于HTML+WebService+Json怎么使用,可以看看Jsonp跨域的相关例子。

本次的实现原理是:通过HTML传送参数到WebService,然后在WebService生成Excel文件,然后保存在服务器上,然后服务器返回文件的相对路径,然后HTML接收到路径,直接下载;
下面我直接贴出WebService的代码;
        /// <summary>
        /// 获取房间每小时报表
        /// </summary>
        [WebMethod(EnableSession = true)]
        public void GetRoomReportOfHour()
        {
            HttpContext.Current.Response.ContentType = "application/json;charset=utf-8";
            string jsonCallBackFunName = HttpContext.Current.Request.Params["jsoncallback"].ToString();
            //上面代码必须,不能注释
            //中间代码执行自己的业务操作,可返回自己的任意信息(多数据类型)
            string strJson = "";
            string Date = HttpContext.Current.Request["Date"];
            string DeptID = HttpContext.Current.Request["DeptID"];
            string BuildId = HttpContext.Current.Request["BuildId"];
            if (!string.IsNullOrWhiteSpace(Date) && !string.IsNullOrWhiteSpace(DeptID) && !string.IsNullOrWhiteSpace(BuildId))
            {
                int iDepartID = DataFormat.ConvertDBNullToInt32(DeptID);
                DateTime dtTime = DataFormat.ConvertDBNullToDateTime(Date);
                List<ModelForDepartmentOrRoomOfHour> mList = DataLoader.GetRoomOfHour(dtTime, DeptID, BuildId);
                if (mList.Count > 0)
                {
                    string strReportDate = DateTime.Now.ToString("yyyy-MM-dd");
                    string strDepartName = DataLoader.GetDepartInfoByDepartID(iDepartID).DeptName;
                    string strBuildName = DataLoader.GetBuildInfoByBuildID(BuildId).F_BuildName;
                    DataTable dtSource = DTListFormat.ListToDataTable(mList);
                    //Excel的路径 是放excel模板的路径
                    WorkbookDesigner designer = new WorkbookDesigner();
                    string strSystemPath = HttpContext.Current.Server.MapPath("~");
                    designer.Open(strSystemPath + "/excel/RoomReportOfHour.xls");
                    Worksheet sheet = designer.Workbook.Worksheets[0];
                    var c124 = sheet.Cells[1, 24];//第二行 第25列,导出日期
                    c124.PutValue(strReportDate);
                    var c33 = sheet.Cells[3, 3];
                    c33.PutValue(strBuildName);
                    var c36 = sheet.Cells[3, 6];
                    c36.PutValue(strDepartName);
                    var c312 = sheet.Cells[3, 12];
                    c312.PutValue(Date);
                    sheet.Cells.ImportDataTable(dtSource, false, 6, 0, true);
                    SaveOptions s = new XlsSaveOptions(SaveFormat.Excel97To2003);
                    string str = "";
                    str = HttpUtility.UrlEncode(string.Format("{0}.xls", DateTime.Now.ToString("yyyyMMddHHmmss")), Encoding.UTF8).ToString();
                    designer.Workbook.Save(strSystemPath + "/Attachment/" + str);//通过这个方法,就可以通过WebService来使用Excel文件保存和文件下载了。
                    ModelForReport aReport = new ModelForReport()
                    {
                        strUrl = "Attachment/" + str
                    };
                    strJson = JsonHelper.Serialize(aReport);
                }
            }
            //下面代码必须,不能注释
            HttpContext.Current.Response.Write(string.Format("{0}({1})", jsonCallBackFunName, strJson));
            HttpContext.Current.Response.End();
        }

HTML端:
            function fExportReportOfDay() {
                var date = $("#IdForDayTime").val();
                var DepartId = $('#DeptID').combobox('getValue') //获取当前选中的值;
                var BuildID = $('#BuildID').combobox('getValue') //获取当前选中的值;
                $.ajax({
                    type: 'GET',
                    url: vUrlPre + 'WebService.asmx/GetRoomReportOfHour?jsoncallback=?',
                    dataType: 'jsonp',
                    data: {
                        Date: date,
                        DeptID: DepartId,
                        BuildId: BuildID
                    },
                    success: function(data) {
                        var vUrl = vUrlPre + data.strUrl;//解释一下,vUrlPre是一个全局的参数,是远程WebService的服务地址,例如:http://www.webservice.com/
                        fDownLoad(vUrl);
                    },
                    error: function(data) {
                        var vData = JSON.stringify(data);
                    }
                })

}  

WebService中使用Aspose.Cells.dll的更多相关文章

  1. C# WinForm 导出导入Excel/Doc 完整实例教程[使用Aspose.Cells.dll]

    [csharp] view plain copy 1.添加引用: Aspose.Cells.dll(我们就叫工具包吧,可以从网上下载.关于它的操作我在“Aspose.Cells操作说明 中文版 下载 ...

  2. C# WinForm使用Aspose.Cells.dll 导出导入Excel/Doc 完整实例教程

    1.添加引用: Aspose.Cells.dll(我们就叫工具包吧,可以从网上下载.关于它的操作我在“Aspose.Cells操作说明 中文版 下载 Aspose C# 导出Excel 实例”一文中的 ...

  3. 在ASP.NET MVC中利用Aspose.cells 将查询出的数据导出为excel,并在浏览器中下载。

    正题前的唠叨 本人是才出来工作不久的小白菜一颗,技术很一般,总是会有遇到一些很简单的问题却不知道怎么做,这些问题可能是之前解决过的.发现这个问题,想着提升一下自己的技术水平,将一些学的新的'好'东西记 ...

  4. C# 读写Excel的一些方法,Aspose.Cells.dll

    需求:现有2个Excel,一个7000,一个20W,7000在20W是完全存在的.现要分离20W的,拆分成19W3和7000. 条件:两个Excel都有“登录名”,然后用“登录名”去关联2个Excel ...

  5. Aspose.Cells.dll引用导入导出Excel

    Aspose.Cells 导入导出EXCEL 文章出处:http://hi.baidu.com/leilongbing/item/c11467e1819e5417595dd8c1 修改样式       ...

  6. Aspose.Cells.dll操作execl

    附件:Aspose.Cells.dll 1.创建execl(不需要服务器或者客户端安装office) public void DCExexl(DataTable dt) {  Workbook wb ...

  7. C# Aspose.Cells.dll Excel操作总结

    简介 Aspose.Cells是一款功能强大的 Excel 文档处理和转换控件,不依赖 Microsoft Excel 环境,支持所有 Excel 格式类型的操作. 下载 Aspose.Cells.d ...

  8. C# 利用Aspose.Cells .dll将本地excel文档转化成pdf(完美破解版 无水印 无中文乱码)

    Aspose.Cells .dll下载  http://pan.baidu.com/s/1slRENLF并引用 C#代码 using System; using System.Collections. ...

  9. Asp.Net中应用Aspose.Cells输出报表到Excel 及样式设置

    解决思路: 1.找个可用的Aspose.Cells(有钱还是买个正版吧,谁开发个东西也不容易): 2.在.Net方案中引用此Cells: 3.写个函数ToExcel(传递一个DataTable),可以 ...

随机推荐

  1. js弹出框、对话框、提示框、弹窗总结

    一.JS的三种最常见的对话框 //====================== JS最常用三种弹出对话框 ======================== //弹出对话框并输出一段提示信息 funct ...

  2. 疯狂C#~伴随着我的库存管理¥

    每次的等待都是期待下一次的勃发!但激进的我非常想和大家学习一些东西,所以特地的分享了一个库存管理, 生活中容易运用的很多,但现在的学业希望能够得到各界人士的帮助!!! 首先:会有几个类来让它们协调 ( ...

  3. nginx 启动不了的小问题

    nginx 配置的端口可能没打开 linux打开端口:  /sbin/iptables -I INPUT -p tcp --dport 8011 -j ACCEPT #开启8011端口   /etc/ ...

  4. SQL Server CheckPoint的几个误区

        有关CheckPoint的概念对大多数SQL Server开发或DBA人员都不陌生.但是包括我自己在内,大家对于CheckPoint都或多或少存在某些误区,最近和高文佳同学(感谢高同学的探讨) ...

  5. ASP.NET Core Kestrel 中使用 HTTPS (SSL)

    在ASP.NET Core中,如果在Kestrel中想使用HTTPS对站点进行加密传输,可以按照如下方式 申请证书 这一步就不详细说了,有免费的和收费的,申请完成之后会给你一个*.pfx结尾的文件. ...

  6. 【Hello CC.NET】CC.NET 实现自动化集成

    一.背景 公司的某一金融项目包含 12 个子系统,新需求一般按分支来开发,测完后合并到主干发布.开发团队需要同时维护开发环境.测试环境.模拟环境(主干).目前面临最大的两个问题: 1.子系统太多,每次 ...

  7. Java NIO3:通道和文件通道

    通道是什么 通道式(Channel)是java.nio的第二个主要创新.通道既不是一个扩展也不是一项增强,而是全新的.极好的Java I/O示例,提供与I/O服务的直接连接.Channel用于在字节缓 ...

  8. Mina入门教程(二)----Spring4 集成Mina

    在spring和mina集成的时候,要十分注意一个问题:版本. 这是一个非常严重的问题,mina官网的demo没错,网上很多网友总结的代码也是对的,但是很多人将mina集成到spring中的时候,总是 ...

  9. jQuery.Callbacks之demo

    jQuery.Callbacks是jquery在1.7版本之后加入的,是从1.6版中的_Deferred对象中抽离的,主要用来进行函数队列的add.remove.fire.lock等操作,并提供onc ...

  10. 使用WCF的Trace与Message Log功能

      原创地址:http://www.cnblogs.com/jfzhu/p/4030008.html 转载请注明出处   前面介绍过如何创建一个WCF Service http://www.cnblo ...