5

可能有一个简单的方法可以做到这一点,但我看不到它......

我创建了一个简单的 Http 模块,它在 PreRequestHandler 上启动计时器并在 PostRequestHandler 上停止计时器,以计算页面加载所用的时间。

然后我创建一些简单的 html 并将结果写入 Response.Write。由于我在 PostRequestHandler 中执行此操作,因此在</html>标记后添加了我的结果。这对测试很好,但我需要在页面需要验证的情况下。

我似乎无法弄清楚如何操纵 Response 对象以在</body>标记之前插入我的结果。Response.Write 和 Response.Output.Write 没有这种灵活性,我看不到将 Response 作为字符串处理的方法。我错过了一些简单的事情吗?

4

1 回答 1

8

为此,您必须实现自己的流对象并将其用作响应的过滤器。

例如:

public class TimerStream : Stream
{
    private Stream inner { get; set; }
    private StringBuilder   responseHtml;

    public TimerStream(Stream inputStream) { 
        inner = inputStream; 
        responseHtml = new StringBuilder();
        // Setup your timer
    }

    /* Filter overrides should pass through to inner, all but Write */
    public override void Write(byte[] buffer, int offset, int count)
    {
        string bufferedHtml = System.Text.UTF8Encoding.UTF8.GetString (buffer, offset, count);
        Regex endTag = new Regex ("</html>", RegexOptions.IgnoreCase);

        if (!endTag.IsMatch (bufferedHtml))
        {
            responseHtml.Append(bufferedHtml);
        }
        else
        {
            // insert timer html into buffer, then...
            responseHtml.Append (bufferedHtml);
            byte[] data = System.Text.UTF8Encoding.UTF8.GetBytes (responseHtml.ToString ());            
            inner.Write (data, 0, data.Length);            
        }
    }
}

然后,在您的 HttpModule 中,将其添加到您的 BeginRequest 中:

// Change the Stream filter
HttpResponse response = context.Response;
response.Filter = new TimerStream(context.Response.Filter);
于 2010-05-07T20:02:51.467 回答