我有一个Asp .Net Web应用程序,其中一些页面继承自基类“BasePage”。 这个BasePage类继承自System.Web.ui.Page并且我覆盖了Render方法,这样我就可以在将HTML流发送到客户端浏览器之前拦截它。
以下是我的渲染方法的代码:
protected override void Render(HtmlTextWriter writer){
MemoryStream memoryStream = new MemoryStream();
try
{
using (StreamWriter streamWriter = new StreamWriter(memoryStream))
{
var textWriter = new HtmlTextWriter(streamWriter);
base.Render(textWriter);
textWriter.Flush();
memoryStream.Position = 0;
using (StreamReader reader = new StreamReader(memoryStream))
{
string finalHtml = reader.ReadToEnd();
// Processing filters
finalHtml = FilterManager.ProcessFilters(finalHtml);
// Writing output to client
writer.Write(finalHtml);
reader.Close();
}
}
}
catch(ObjectDisposedException)
{
}
finally
{
memoryStream.Dispose();
}
}
到目前为止,这么好。有用。我没有使用response filtering feature的原因是我知道it wouldn't be compatible with Post-cache substitution
是。我也想使用outputcache替换。出于测试目的,我在我的aspx页面中添加了一个小的asp .net控件:
<asp:Substitution runat="server" id="UnCachedArea" methodname="GetFreshDateTime" />
在后面的代码中使用相应的静态方法:
protected static string GetFreshDateTime(HttpContext context)
{
return DateTime.Now.ToString();
}
......而且......它有效!!我的两个过滤器只在第一页加载时工作,并且我在页面上进行的每次刷新都会发生替换。
替换字符串插入到错误的位置,就在打开的body标签之后,而我的susbtitution控件位于页面的最底部,在页脚中。
任何线索?
答案 0 :(得分:1)
这是因为您修改了渲染以将输出展平为单个字符串,这就是缓存的内容。
通常使用环形缓存,缓存的渲染输出会在缓存后的缓存中填充替换块的动态区域标记。在将字符串直接写入HtmlTextWriter时,您已经破坏了ASP.NET执行此操作的能力。这就是为什么你不能使用ResponseFilters的原因。
Scott Gu在这个问题上表现良好article