首先,目前我是在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. fatal error

    1.   fatal error C1083: 无法打开源文件 编译报此错误:  1>c1xx : fatal error C1083: 无法打开源文件:“Projects\XXXCCCC\VB ...

  2. JSON详解

    首先要知道JSON是一种轻量级的数据格式,不是一种编程语言,因此其他语言也可以使用. 一.JSON语法 JSON语法可以表现为下面三种值: 1.简单值:字符串.数值.布尔值和null,如"h ...

  3. Unity自动寻路Navmesh之入门

    实例 我们要实现一个功能:点击场景中的一个位置,角色可以自动寻路过去.角色会绕过各种复杂的障碍,找到一条理论上”最短路径“. 步骤 1.创建地形 2.添加角色 3.创建多个障碍物,尽量摆的复杂一点,来 ...

  4. centos 7.2 安装PHP7.1+apache2.4.23

    安装准备:   http://ftp.cuhk.edu.hk/pub/packages/apache.org//httpd/httpd-2.4.23.tar.gz 下载apache http://cn ...

  5. 编译可在Nexus5上运行的CyanogenMod13.0 ROM(基于Android6.0)

    编译可在Nexus5上运行的CyanogenMod13.0 ROM (基于Android6.0) 作者:寻禹@阿里聚安全 前言 下文中无特殊说明时CM代表CyanogenMod的缩写. 下文中说的“设 ...

  6. 负载均衡的场景下ASP.NET Core如何获取客户端IP地址

    在ASP.NET中,使用负载均衡时,可以通过ServerVariables获取客户端的IP地址. var ip = request.ServerVariables["HTTP_X_FORWA ...

  7. this的安身之处

    在JavaScript的大千世界中,this对象就像一个行踪不定.居无定所的浪子一般,它的生活仿佛可以随处而安,而内心却又似有着笃定的坚守,它就是这么有趣! 初学JavaScript时的我们,多多少少 ...

  8. MySQL 处理插入过程中的主键唯一键重复值办法

    200 ? "200px" : this.width)!important;} --> 介绍 本篇文章主要介绍在插入数据到表中遇到键重复避免插入重复值的处理方法,主要涉及到I ...

  9. js框架模版

    (function() { //注册命名空间zzw到window对象上 window['zzw'] = {} //定义一个$函数 function $() { alert("hello $& ...

  10. ASP.NET MVC 过滤器(一)

    ASP.NET MVC 过滤器(一) 前言 前面的篇幅中,了解到了控制器的生成的过程以及在生成的过程中的各种注入点,按照常理来说篇幅应该到了讲解控制器内部的执行过程以及模型绑定.验证这些知识了.但是呢 ...