Webページをwordまたはexcelとして保存する簡単な実装

2385 ワード

最近ウェブページの導出をして、ネット上で多くの方法を探して、最後に1種の比較的に簡単な方法で実現して、今回の探求と問題を解決する過程は私にパッケージと対象に対する理解をもっと深くさせました!B/S段階では、すでにパッケージされたクラスがたくさんあり、すべてのページでクラスが1つずつですが、私たちが頻繁に使用しているだけで、彼らを無視しているわけではありません.例えば今日の問題は、実はioクラスの1つの使用です!
まず、ページ・レイヤにプロパティを追加します.
にある
<%@ PageLanguage="C#"AutoEventWireup="true"CodeBehind="printPage.aspx.csEnableEventValidation="false" Inherits="ExamSystemV3.Web.Student.printPage"%>
の中でEnableEventValidation値をfalseに設定するのは、主にページをエクスポートする際のセキュリティ検証を避け、エクスポートの円滑な進行を保証することです.
次に、ページのバックグラウンドにメソッドを追加します.
        public void ExpertControl(System.Web.UI.Control source, DocumentType type)
        {
            //  Http    ,    
            if (type == DocumentType.Excel)
            {
                //Excel
                Response.AppendHeader("Content-Disposition", "attachment;filename=result.xls");
                Response.ContentType = "application/ms-excel";
            }
            else if (type == DocumentType.Word)
            {
                //Word
                Response.AppendHeader("Content-Disposition", "attachment;filename=result.doc");
                Response.ContentType = "application/ms-word";
            }
	//      ——utf-8       ,word               utf-8 gb2312
            Response.Charset = "utf-8";
            Response.ContentEncoding = System.Text.Encoding.GetEncoding("utf-8");
            //         
            source.Page.EnableViewState = false;
            //   HtmlWriter
            System.IO.StringWriter writer = new System.IO.StringWriter();
            System.Web.UI.HtmlTextWriter htmlWriter = new System.Web.UI.HtmlTextWriter(writer);
            source.RenderControl(htmlWriter);
            //  
            Response.Write(writer.ToString());
            Response.End();
        }
        //      
        public enum DocumentType
        {
            Word,
            Excel
        }

最後に、使用時に呼び出されます.
たとえば、エクスポートのボタンを追加しました.
        protected void Button1_Click(object sender, EventArgs e)
        {

            ExpertControl(this, DocumentType.Word);


        }

この简単な例の解决は1种の积み重ねで、主に私达の知らない问题を解决して、私达に自分のどんな问题を意识させて、どんな种类を探すべきです!対象の今日に向かって、私达の解决の考えは、ただ、多く知っているだけかもしれません!多く知っています!しかし后でインターネットで调べます!最后に熟知して掌握します!