ASP.NETサーバが生成したクライアントに送信するhtmlをキャプチャする方法

4274 ワード

サーバ側で生成されたhtmlをクライアントに送信する前に、静的htmlの生成に加えて保存したり、生成されたhtmlの一部を変更したりするなど、これらのhtmlを操作する必要がある場合があります.
私は2つの方法をまとめました.個人的には使いやすいと思います.1つはPageを書き直すことです.Render()メソッド.1つはIHttpmoduleによって実現される.
1)この方法はあるページを制御するのに適している.aspx.csにはRender()メソッドを書き換えることができ、このメソッドはHtmlTextWriterタイプのパラメータを提供し、クライアントに送信する内容が含まれている.asp.Net宣言サイクルはRenderフェーズがloadイベントの後にトリガーされることを知っているので,この方法は我々が望む効果を達成するのに適している.簡単な例を次に示します.
   1:      protected override void Render(HtmlTextWriter writer)
   2:      {
   3:          TextWriter tempWriter = new StringWriter();
   4:          base.Render(new HtmlTextWriter(tempWriter));
   5:          string str = tempWriter.ToString(); //  str       html。
   6:   
   7:         //              ,    、    
   8:          writer.Write(str); //      html      
   9:      }
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
2)この方法は,ある種類のページを処理したり,すべてのページを比較したりする必要があるレベル制御を適用するのに適している.インタフェースのPreSendRequestContentメソッドを登録するには、次の例を示します.IHttpmoduleの内容については、ここでは繰り返しません.
   1:          void context_PreSendRequestContent(object sender, EventArgs e)
   2:          {
   3:              HttpApplication app = (HttpApplication)sender;
   4:              HttpContext context = app.Context;
   5:              string url = context.Request.RawUrl;
   6:              StringWriter wr = new StringWriter();
   7:              context.Server.Execute(url, wr);
   8:              string htmlCon = wr.ToString();//   htmlCon               html。
   9:   
  10:          }
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
3)Responseを置き換える.Filterも実現できます.