using KYZWeb.Common;
using Liger.Data;
//using Microsoft.Office.Interop.Excel;
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using System.Web;

namespace KYZWeb.Modules.DeviceMan
{
    /// <summary>
    /// ExportHandler 的摘要说明
    /// </summary>
    public class ExportHandler : IHttpHandler
    {

public static DbContext DB = DbHelper.Db;
        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";

string startdatetime = context.Request.Params["startdatetime"];
            string enddatetime = context.Request.Params["enddatetime"];
            string user_name = context.Request.Params["user_name"];
            StringBuilder sql = new StringBuilder();
            sql.Append(@"   select  * ");
            sql.Append("  from dbo.vi_card_run WHERE 1=1");
            if (!string.IsNullOrEmpty(startdatetime))
            {
                sql.Append(" and card_datetime >= '" + startdatetime + "'");
            }
            if (!string.IsNullOrEmpty(enddatetime))
            {
                sql.Append(" and card_datetime <= '" + enddatetime + "'");
            }
            if (!string.IsNullOrEmpty(user_name))
            {
                sql.Append(" and user_name like '%" + user_name + "%'");
            }
            sql.Append(" order by card_datetime desc");
            //创建command
            var dt = DB.Db.ExecuteDataSet(CommandType.Text, sql.ToString()).Tables[0];

StringWriter sw = new StringWriter();
            //sw.WriteLine("姓名\t工号\t打卡时间\t打卡地点\t打卡设备");
            sw.WriteLine("<html xmlns:x=\"urn:schemas-microsoft-com:office:excel\">");
            sw.WriteLine("<head>");
            sw.WriteLine("<!--[if gte mso 9]>");
            sw.WriteLine("<xml>");
            sw.WriteLine(" <x:ExcelWorkbook>");
            sw.WriteLine("  <x:ExcelWorksheets>");
            sw.WriteLine("   <x:ExcelWorksheet>");
            sw.WriteLine("    <x:Name>" + "sheetName" + "</x:Name>");
            sw.WriteLine("    <x:WorksheetOptions>");
            sw.WriteLine("      <x:Print>");
            sw.WriteLine("       <x:ValidPrinterInfo />");
            sw.WriteLine("      </x:Print>");
            sw.WriteLine("    </x:WorksheetOptions>");
            sw.WriteLine("   </x:ExcelWorksheet>");
            sw.WriteLine("  </x:ExcelWorksheets>");
            sw.WriteLine("</x:ExcelWorkbook>");
            sw.WriteLine("</xml>");
            sw.WriteLine("<![endif]-->");
            sw.WriteLine("</head>");
            sw.WriteLine("<body>");
            sw.WriteLine("<table border='1'>");
            sw.WriteLine(" <tr >");
            sw.WriteLine("  <td><strong>姓名</strong></td>");
            sw.WriteLine("  <td><strong>工号</strong></td>");
            sw.WriteLine("  <td><strong>打卡时间</strong></td>");
            sw.WriteLine("  <td><strong>打卡地点</strong></td>");
            sw.WriteLine("  <td><strong>打卡设备</strong></td>");
            
            sw.WriteLine(" </tr>");

foreach (DataRow dr in dt.Rows)
            {
                //sw.WriteLine(dr["user_name"] + "\t" + dr["user_code"] + "\t" + dr["card_datetime"]+"\t"+dr["card_address"]+"\t"+dr["card_device_name"]);
                sw.WriteLine(" <tr>");
                sw.WriteLine("  <td>" + dr["user_name"] + "</td>");
                sw.WriteLine("  <td>" + dr["user_code"] + "</td>");
                sw.WriteLine("  <td>" + dr["card_datetime"] + "</td>");
                sw.WriteLine("  <td>" + dr["area_name"] + "</td>");
                sw.WriteLine("  <td>" + dr["device_name"] + "</td>");
            
                sw.WriteLine(" </tr>");
            }
            sw.WriteLine("</table>");
            sw.WriteLine("</body>");
            sw.WriteLine("</html>");
            sw.Close();
            context.Response.Clear();
            context.Response.Buffer = true;
            context.Response.Charset = "UTF-8";

context.Response.AddHeader("Content-Disposition", "attachment; filename=" + "card" + ".xls");
            context.Response.ContentType = "application/ms-excel";
            context.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
            context.Response.Write(sw);
            context.Response.End();
            //context.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
            //context.Response.AddHeader("Content-Disposition", "attachment; filename=" + System.Web.HttpUtility.UrlEncode("card", System.Text.Encoding.UTF8) + ".xls");
            //context.Response.ContentType = "application/ms-excel";
            //context.Response.Write(sw);
            //context.Response.End();

//DataTabletoExcel(dt, "C:\\中国.XLS");   //调用自定义的函数,当然输出文件你可以随便写
        }

public static void DataTabletoExcel(System.Data.DataTable tmpDataTable, string strFileName)
        {

if (tmpDataTable == null)

return;

int rowNum = tmpDataTable.Rows.Count;

int columnNum = tmpDataTable.Columns.Count;

int rowIndex = 1;

int columnIndex = 0;

//Application xlApp = new ApplicationClass();

//xlApp.DefaultFilePath = "";

//xlApp.DisplayAlerts = true;

//xlApp.SheetsInNewWorkbook = 1;

//Workbook xlBook = xlApp.Workbooks.Add(true);

////将DataTable的列名导入Excel表第一行

//foreach (DataColumn dc in tmpDataTable.Columns)
            //{

//    columnIndex++;

//    xlApp.Cells[rowIndex, columnIndex] = dc.ColumnName;

//}

////将DataTable中的数据导入Excel中

//for (int i = 0; i < rowNum; i++)
            //{

//    rowIndex++;

//    columnIndex = 0;

//    for (int j = 0; j < columnNum; j++)
            //    {

//        columnIndex++;

//        xlApp.Cells[rowIndex, columnIndex] = tmpDataTable.Rows[i][j].ToString();

//    }

//}

////xlBook.SaveCopyAs(HttpUtility.UrlDecode(strFileName, System.Text.Encoding.UTF8));

//xlBook.SaveCopyAs(strFileName);

}

public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}

ExportHandler.ashx的更多相关文章

  1. Visual Studio 2013 添加一般应用程序(.ashx)文件到SharePoint项目

    默认,在用vs2013开发SharePoint项目时,vs没有提供一般应用程序(.ashx)的项目模板,本文解决此问题. 以管理员身份启动vs2013,创建一个"SharePoint 201 ...

  2. ashx中Response.ContentType的常用类型

    ashx中Response.ContentType的常用类型: text/plaintext/htmltext/xmlapplication/jsonimage/GIFapplication/x-cd ...

  3. 一种开发模式:ajax + ashx + UserControl

    一.ajax+ashx模式的缺点     在web开发过程中,为了提高网站的用户体验,或多或少都会用到ajax技术,甚至有的网站全部采用ajax来实现,大量使用ajax在增强用户体验的同时会带来一些负 ...

  4. 如何使用VS在SharePont 2013中插入ashx文件

    http://www.lifeonplanetgroove.com/adding-and-deploying-generic-handlers-ashx-to-a-sharepoint-2010-vi ...

  5. 分享一个html+js+ashx+easyui+ado.net权限管理系统

    EasyUI.权限管理 这是个都快被搞烂了的组合,但是easyui的确好用,权限管理在项目中的确实用.一直以来博客园里也不少朋友分享过,但是感觉好的要不没源码,要不就是过度设计写的太复杂看不懂,也懒得 ...

  6. 在一个aspx或ashx页面里进行多次ajax调用

    在用ajax开发asp.net程序里.利用ashx页面与前台页面进行数据交互.但是每个ajax交互都需要一个ashx页面.结果是项目里一大堆ashx页面.使项目难以管理.现在我们就想办法让一个ashx ...

  7. 在ashx文件中制作验证码(使用session要继承IRequiresSessionState)

    必须继承System.Web.SessionState.IRequiresSessionState接口,才能实现Session读写! System.Web.SessionState的一些接口 IRea ...

  8. jsonp跨域+ashx(示例)

    前言 做B/S项目的时候,我们一般使用jquery+ashx来实现异步的一些操作,比如后台获取一些数据到前台,但是如果ashx文件不在本项目下,引用的是别的域下的文件,这时候就访问不了.关于jsonp ...

  9. ztree + ashx +DataTable +Oracle

    问题描述 好久没有使用ztree了,刚才在使用ztree做导航时遇到了几个小问题: 1.返回数据源是undefined . 2.数据出现后树结构没有出现(pIdKey单词拼写错误). 3.在使用Ora ...

随机推荐

  1. C++ —— 返回数组指针的函数 和 返回指向函数的指针的函数

    返回数组指针的函数 基础知识:数组不能被拷贝,函数不能返回数组,只能返回数组的指针或者引用. 定义一个 返回数组指针的函数 的方法,以 一个接收参数为 含有10个整型元素的数组的引用  和 返回一个含 ...

  2. IDE安装Lombok插件提高开发效率

    Lombok官方api:https://projectlombok.org/features/index.html 使用lombok之后,省去了许多没必要的get,set,toString,equal ...

  3. 【转】MySQL中的共享锁与排他锁

    在MySQL中的行级锁,表级锁,页级锁中介绍过,行级锁是Mysql中锁定粒度最细的一种锁,行级锁能大大减少数据库操作的冲突.行级锁分为共享锁和排他锁两种,本文将详细介绍共享锁及排他锁的概念.使用方式及 ...

  4. Nginx+IIS简单的部署

    随着互联网项目用户访问量不断上升,单点web服务器是无法满足大型高并发高负载的业务处理的,为了给web服务器做负载均衡方案,打算采用Nginx搭建负载均衡服务器,把用户请求分配到N个服务器来缓解服务器 ...

  5. iScroll.js 向上滑动异步加载数据回弹问题

    iScroll是一款用于移动设备web开发的一款插件.像缩放.下拉刷新.滑动切换等移动应用上常见的一些效果都可以轻松实现. 现在最新版本是5.X,官网这里:http://iscrolljs.com/ ...

  6. 【JS小技巧】JavaScript 函数用作对象的隐藏问题(F.ui.name)

    用户反馈 @消失的键盘 在论坛反馈了一个问题,在 AppBoxMvc 中的 Title 模型中,如果将 Name 属性改名为小写的 name 属性,就会报错: 因为这是一个 ASP.NET MVC 的 ...

  7. matplotlib 入门之Usage Guide

    文章目录 Usage Guide plotting函数的输入 matplotlib, pyplot, pylab, 三者的联系 Coding style Backends 后端 matplotlib教 ...

  8. 广州商学院16级软工一班&二班-第一次作业成绩

    广州商学院16级软工一班&二班-第一次作业成绩 作业地址 16软工一班 16软工二班 总结 本次作业反映了几个比较严重的问题: 不按要求阅读相应的文章,回答问题只是敷衍几句. 部分同学的版式混 ...

  9. Day12 Python基础之生成器、迭代器(高级函数)(十)

    https://www.cnblogs.com/yuanchenqi/articles/5769491.html 1. 列表生成式 我现在有个需求,看列表[0, 1, 2, 3, 4, 5, 6, 7 ...

  10. 20分钟 看图手写的table

    <html><body><table width="100%" border="1" cellspacing="0&qu ...