protected void Button1_Click(object sender, EventArgs e)
{
string strsql = "select * from TreeViewTemp where parentID=0";
DataTable dt = db.GetDataTable(strsql);
StringWriter sw = new StringWriter();
//StreamWriter sw = new StreamWriter("d:\\test.xls",false,System.Text.Encoding.Default); ±¾µØ±£´æ
ExportExcel(dt, sw);
Response.AddHeader("Content-Disposition", "attachment; filename=PDSDATA.xls");//遠³ÌÏÂ載
Response.ContentType = "application/ms-excel";
Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
Response.Write(sw);
Response.End();
}
public void ExportExcel(DataTable dt, StringWriter w)
{
try
{
for (int i = 0; i < dt.Columns.Count; i++)
{
w.Write ......
protected void Button1_Click(object sender, EventArgs e)
{
string strsql = "select * from TreeViewTemp where parentID=0";
DataTable dt = db.GetDataTable(strsql);
StringWriter sw = new StringWriter();
//StreamWriter sw = new StreamWriter("d:\\test.xls",false,System.Text.Encoding.Default); ±¾µØ±£´æ
ExportExcel(dt, sw);
Response.AddHeader("Content-Disposition", "attachment; filename=PDSDATA.xls");//遠³ÌÏÂ載
Response.ContentType = "application/ms-excel";
Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
Response.Write(sw);
Response.End();
}
public void ExportExcel(DataTable dt, StringWriter w)
{
try
{
for (int i = 0; i < dt.Columns.Count; i++)
{
w.Write ......
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.IO;
namespace AJAXEnabledWebApplication1
{
public partial class excelOutput : System.Web.UI.Page
{
DBClass db = new DBClass();
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
string strsql = "select * from TreeViewTemp where parentID=0";
DataTable dt = db.GetDataTable(strsql);
this.GridView1.DataSource = dt;
this.GridView1.DataBind();
}
}
protected void Button1_Click(object sender, EventArgs e)
{
OutPutExcel();
}
//´Ë´¦Òª×¢Òâ,Õâ¸öÖØÔØ·½·¨,Ò»¶¨ÒªÐ´,²»È» ......
Êý¾Ý°ó¶¨ÒÔ¼°Container.DataItemµÄ¾ßÌå·ÖÎö
Áé»îµÄÔËÓÃÊý¾Ý°ó¶¨²Ù×÷
°ó¶¨µ½¼òµ¥ÊôÐÔ:<%#UserName%>
°ó¶¨µ½¼¯ºÏ:<asp:ListBox id="ListBox1" datasource='<%# myArray%>' runat="server">
°ó¶¨µ½±í´ïʽ:<%#(class1.property1.ToString() + "," + class1.property2.ToString())%>
°ó¶¨µ½·½·¨·µ»ØÖµ:<%# GetSafestring(str) %>
°ó¶¨µ½Hashtable:<%# ((DictionaryEntry)Container.DataItem).Key%>
°ó¶¨µ½ArrayList:<%#Container.DataItem %>
ÈôÊý×éÀïÀï·ÅµÄÊǶÔÏóÔò¿ÉÄÜÒª½øÐбØÒªµÄת»»ºóÔÙ°ó¶¨Èç:
<%#((¶ÔÏóÀàÐÍ)Container.DataItem).ÊôÐÔ%>
°ó¶¨µ½DataView,DataTable,DataSet:
<%#((DataRowView)Container.DataItem)["×Ö¶ÎÃû"]%>»ò
<%#((DataRowView)Container.DataItem).Rows[0]["×Ö¶ÎÃû"]%>
Òª¸ñʽ»¯Ôò:
<%#string.Format("¸ñʽ",((DataRowView)Container.DataItem)["×Ö¶ÎÃû"])%>
<%#DataBinder.Eval(Container.DataItem,"×Ö¶ÎÃû","¸ñʽ")%>
°ó¶¨µ½DataReader:
<%#((IDataReader)Container.DataItem).×Ö¶ÎÃû%>
µ±È»ÎªÁË·½±ãÒ»°ãʹÓÃ×î¶àµÄ¾ÍÊÇDataBinderÀàµÄEval·½·¨ÁË.²» ......
Asp.Net ¹¹¼Ü(Http Handler ½éÉÜ) - Part.2
ÒýÑÔ
ÔÚ Part.1 HttpÇëÇó´¦ÀíÁ÷³Ì Ò»ÎÄÖУ¬ÎÒÃÇÁ˽âÁËHttpÇëÇóµÄ´¦Àí¹ý³ÌÒÔ¼°ÆäËüһЩÔË×÷ÔÀí¡£ÎÒÃÇÖªµÀHttp¹ÜµÀÖÐÓÐÁ½¸ö¿ÉÓýӿڣ¬Ò»¸öÊÇIHttpHandler£¬Ò»¸öÊÇIHttpModule£¬µ«ÔÚPart.1ÖУ¬ÎÒ²¢Ã»ÓÐÏêϸ½²ÊöÈçºÎ¶ÔËüÃǽøÐбà³Ì£¬Ö»ÊÇÇáÃèµÐ´µØÒ»±Ê´ø¹ý¡£ËùνѧÒÔÖÂÓã¬Ç°ÃæÒѾ½éÉÜÁ˲»ÉÙ¸ÅÄîºÍÔÀí¡£ÔÚ±¾ÎÄÖУ¬ÎÒÃÇͨ¹ý¼¸¸ö·¶ÀýÀ´Á˽â IHttpHandler£¬¿´¿´ÕÆÎÕÕâЩÔÀíµÄʵ¼ÊÓÃ;¡£
IHttpHandler ¸ÅÊö
¿ÉÄܺÍÎÒÒ»Ñù£¬ºÜ¶àAsp.Net¿ª·¢ÈËÔ±¶¼ÓйýAspµÄ±³¾°£¬ÒÔÖÁÓÚÎÒÃÇÔÚ¿ª·¢³ÌÐòµÄʱºò£¬Í¨³£¶¼ÊÇÔÚ“Ò³Ãæ¼¶”ÉÏ˼¿¼£¬Ò²¾ÍÊÇ˵ÎÒÃÇÏÖÔÚÕýÔÚ×öµÄÕâ¸öÒ³ÃæÓ¦¸ÃÓÐʲôÑùµÄ¹¦ÄÜ£¬ÊǽøÐÐÒ»¸öÎʾíµ÷²é»¹ÊÇÒ»¸öÊý¾Ý¿â²éѯµÈµÈ¡£¶øºÜÉÙÔÚ“ÇëÇ󼶔˼¿¼£¬¿¼ÂÇÓÐûÓа취À´Í¨¹ý±àÂëµÄ·½Ê½À´²Ù¿ØÒ»¸öHttpÇëÇó¡£
ʵ¼ÊÉÏ£¬FrameworkÌṩÁËһϵÁеĽӿںÍÀ࣬ÔÊÐíÄã¶ÔÓÚHttpÇëÇó½øÐбà³Ì£¬¶øÊµÏÖÕâÒ»²Ù×÷µÄÒ»¸öÖ÷ÒªµÄ½Ó¿Ú£¬¾ÍÊÇ IHttpHandler(ÁíÒ»¸öÊÇIHttpModule)¡£
Ó¦¸Ã»¹¼ÇµÃµÚÒ»½ÚÖÐÎÒÃÇÌáµ½¹ý ISAPI£¬Ëü¸ù¾ÝÎļþÃûºó׺°Ñ²»Í¬µÄÇëÇóת½»¸ø²»Í¬µÄ´¦Àí³ÌÐò¡£µ«ÊÇ×Ðϸ¿´¿´¾Í»á·¢ÏÖ£º¼¸ºõÒ»´ó°ëµÄÎļþ¶¼½»¸ø aspnet_isa ......
a. ReportViewer¹ØÁªReport1.rdlcµÄ¼òµ¥³ÊÏÖ
b. ¶Ô´øÓб¨±í²ÎÊýµÄReport1.rdlcµÄ³ÊÏÖ
c.
ÀûÓóÌʽÉú³ÉµÄDataSet Ìî³ä±¨±í
d. µ÷Óô洢¹ý³Ì Éú³ÉDataSet Ìî³ä±¨±í
==========
¼òµ¥µÄ³ÊÏÖ
==========
1. ´ò¿ªVS2005£¬Îļþ->н¨->ÍøÕ¾ Ñ¡ÔñÓïÑÔÖÖÀࣨC#£©
2. Ôڸýâ¾ö·½°¸ÏÂ
Éè¼ÆÆäÒѾÉú³ÉµÄDefault.aspx
3. ½«¹¤¾ßÏä-Êý¾ÝϵÄReportViewer ÀÈëDefault.aspxµÄÉè¼Æ½çÃæ
4.
ÔÚÓÃÊó±êÑ¡ÖÐReportViewer1ʱ ¿ÉÒÔ¿´µ½ÆäÓÒÉÏ½ÇµÄ Ð¡Èý½Ç ͼ±ê
5. ÓÃÊó±êµã»÷¸ÃСÈý½Ç ½«Õ¹¿ª ReportViewerÈÎÎñ
¿ì½Ý²Ëµ¥
6. ÓÉÓÚ±¾ÏîÄ¿ Ŀǰ»¹Ã»ÓÐ×öºÃµÄ±¨±í ËùÒÔ Ñ¡Ôñ Éè¼ÆÐ±¨±í
7. µã»÷ Éè¼ÆÐ±¨±í ºó
½«³ÊÏÖ±¨±íReport1.rdlcµÄÉè¼Æ½çÃæ
8. ÓÉÓÚ±¾ÏîÄ¿ Ŀǰ»¹Ã»ÓÐ×öºÃµÄÍøÕ¾Êý¾ÝÔ´
ËùÒÔ ´ËʱҪÌí¼ÓÐÂÊý¾ÝÔ´
£¨Èç¹ûûÓгÊÏÖ“ÍøÕ¾Êý¾ÝÔ´”½çÃæ£¬¿ÉÒÔµã»÷±¨±íÉè¼Æ½çÃæ£¬
´ËʱÉÏ·½²Ëµ¥Öжà³öÏÖ“Êý¾Ý”£¬“±¨±í”µÈÑ¡Ïî
¿ÉÒÔÔÚ“Êý¾Ý”²Ëµ¥Ï£¬Ñ¡Ôñ“ÏÔʾÊý¾ÝÔ´”£©
9. µã»÷“Ìí¼ÓÐÂÊý¾ÝÔ´” »á³öÏÖ“TableAdapter ÅäÖÃÏòµ¼”
10.
......
a. ReportViewer¹ØÁªReport1.rdlcµÄ¼òµ¥³ÊÏÖ
b. ¶Ô´øÓб¨±í²ÎÊýµÄReport1.rdlcµÄ³ÊÏÖ
c.
ÀûÓóÌʽÉú³ÉµÄDataSet Ìî³ä±¨±í
d. µ÷Óô洢¹ý³Ì Éú³ÉDataSet Ìî³ä±¨±í
==========
¼òµ¥µÄ³ÊÏÖ
==========
1. ´ò¿ªVS2005£¬Îļþ->н¨->ÍøÕ¾ Ñ¡ÔñÓïÑÔÖÖÀࣨC#£©
2. Ôڸýâ¾ö·½°¸ÏÂ
Éè¼ÆÆäÒѾÉú³ÉµÄDefault.aspx
3. ½«¹¤¾ßÏä-Êý¾ÝϵÄReportViewer ÀÈëDefault.aspxµÄÉè¼Æ½çÃæ
4.
ÔÚÓÃÊó±êÑ¡ÖÐReportViewer1ʱ ¿ÉÒÔ¿´µ½ÆäÓÒÉÏ½ÇµÄ Ð¡Èý½Ç ͼ±ê
5. ÓÃÊó±êµã»÷¸ÃСÈý½Ç ½«Õ¹¿ª ReportViewerÈÎÎñ
¿ì½Ý²Ëµ¥
6. ÓÉÓÚ±¾ÏîÄ¿ Ŀǰ»¹Ã»ÓÐ×öºÃµÄ±¨±í ËùÒÔ Ñ¡Ôñ Éè¼ÆÐ±¨±í
7. µã»÷ Éè¼ÆÐ±¨±í ºó
½«³ÊÏÖ±¨±íReport1.rdlcµÄÉè¼Æ½çÃæ
8. ÓÉÓÚ±¾ÏîÄ¿ Ŀǰ»¹Ã»ÓÐ×öºÃµÄÍøÕ¾Êý¾ÝÔ´
ËùÒÔ ´ËʱҪÌí¼ÓÐÂÊý¾ÝÔ´
£¨Èç¹ûûÓгÊÏÖ“ÍøÕ¾Êý¾ÝÔ´”½çÃæ£¬¿ÉÒÔµã»÷±¨±íÉè¼Æ½çÃæ£¬
´ËʱÉÏ·½²Ëµ¥Öжà³öÏÖ“Êý¾Ý”£¬“±¨±í”µÈÑ¡Ïî
¿ÉÒÔÔÚ“Êý¾Ý”²Ëµ¥Ï£¬Ñ¡Ôñ“ÏÔʾÊý¾ÝÔ´”£©
9. µã»÷“Ìí¼ÓÐÂÊý¾ÝÔ´” »á³öÏÖ“TableAdapter ÅäÖÃÏòµ¼”
10.
......
ASP.NETÒ³ÃæÌø×ªÓÐʲô·½·¨ÄØ£¿£¬ÏÖÔÚ¸ø´ó¼Ò½éÉÜÈýÖÖ·½·¨£¬ËûÃǵÄÇø±ðÊÇÊ²Ã´ÄØ£¿ÈÃÎÒÃÇ¿ªÊ¼°É£º ASP.NETÒ³ÃæÌø×ª1¡¢response.redirect Õâ¸öÌø×ªÒ³ÃæµÄ·½·¨Ìø×ªµÄËٶȲ»¿ì£¬ÒòΪËüÒª×ß2¸öÀ´»Ø(2´Îpostback)£¬µ«Ëû¿ÉÒÔÌø×ªµ½ÈκÎÒ³Ãæ£¬Ã»ÓÐÕ¾µãÒ³ÃæÏÞÖÆ(¼´¿ÉÒÔÓÉÑÅ»¢Ìøµ½ÐÂÀË)£¬Í¬Ê±²»ÄÜÌø¹ýµÇ¼±£»¤¡£µ«ËÙ¶ÈÂýÊÇÆä×î´óȱÏÝ!redirectÌø×ª»úÖÆ£ºÊ×ÏÈÊÇ·¢ËÍÒ»¸ö httpÇëÇ󵽿ͻ§¶Ë£¬Í¨ÖªÐèÒªÌø×ªµ½ÐÂÒ³Ãæ£¬È»ºó¿Í»§¶ËÔÚ·¢ËÍÌø×ªÇëÇóµ½·þÎñÆ÷¶Ë¡£ÐèҪעÒâµÄÊÇÌø×ªºóÄÚ²¿¿Õ¼ä±£´æµÄËùÓÐÊý¾ÝÐÅÏ¢½«»á¶ªÊ§£¬ËùÒÔÐèÒªÓõ½session¡£ ASP.NETÒ³ÃæÌø×ª2¡¢server.transfer Ëٶȿ죬ֻÐèÒªÒ»´Îpostback ,µ«ÊÇ¡£¡£¡£¡£Ëû±ØÐëÊÇÔÚͬһ¸öÕ¾µãÏ£¬ÒòΪËüÊÇserverµÄÒ»¸ö·½·¨¡£ÁíÍ⣬ËûÄÜÌø¹ýµÇ¼±£»¤¡£Äã¿ÉÒÔд¸öС³ÌÐòÊÔÊÔ£ºÉè¼ÆÒ»¸öÓÉÒ³ÃæÒ»µ½Ò³Ãæ¶þµÄÌø×ª£¬µ«Òª½øÈëµ½Ò³Ãæ¶þÐèÒªµÇ¼£¬formÈÏÖ¤£¬µ«Èç¹ûÌø×ªÓï¾äʹÓÃtransferµÄ»°£¬ÄǾͲ»»áµ¯³öµÇÂ¼Ò³ÃæÁË¡£Õâ¸ö·½·¨µÄÖØ¶¨ÏòÇëÇóÊÇ·¢ÉúÔÚ·þÎñÆ÷¶Ë£¬ËùÒÔä¯ÀÀÆ÷µÄurlµØÖ·ÈÔÈ»±£ÁôµÄÊÇÔÒ³ÃæµÄµØÖ·! ASP.NETÒ³ÃæÌø×ª3¡¢sever.execute Õâ¸ö·½·¨Ö÷ÒªÊÇÓÃÔÚÒ³ÃæÉè¼ÆÉÏÃæ£¬¶øÇÒËû±ØÐëÊÇÌø×ªÍ¬Ò»Õ¾µãϵÄÒ³Ãæ¡£Õâ¸ö·½·¨ÊÇÐèÒª½«Ò»¸öÒ³ÃæµÄÊä³ö½á¹û²åÈëµ½Á ......