Я пытаюсь получить [CompressFilter], работая с кэшированием пончиков и сталкиваясь с проблемами.
Что происходит, так это то, что вся страница кэшируется, а не только пончик. Источник для CompressFilter
, который я использую, приведен ниже. Я изменил это из исходного источника, чтобы использовать OnResultExecuted
вместо OnActionExecuting()
, потому что мне нужен был доступ к типу результата, чтобы избежать кеширования определенных Подклассы ActionResult.
Глядя на фактический исходный код MVC v1 для OutputCacheAttribute
, похоже, что он также использует OnResultExecuted()
, но я не думаю, что этот факт непосредственно вызывает конфликт.
Я не знаю достаточно о том, как работает кэширование подстановок, чтобы понять, почему оно ведет себя так, как оно делает. Я думаю, что можно сказать, что это не заканчивается каким-либо искаженным дисплеем. Это просто ведет себя, как нет пончика!
Похоже, мне придется использовать какой-то плагин IIs для обработки кеширования, чего я действительно хотел избежать, но его похоже, что мне нужно кэширование пончиков.
На самом деле я больше заинтересован в том, чтобы понять, почему он имеет этот эффект, но решение, если возможно, тоже будет большим.
public class CompressFilter : ActionFilterAttribute
{
public override void OnResultExecuted(ResultExecutedContext filterContext)
{
HttpRequestBase request = filterContext.HttpContext.Request;
// dont encode images!
if (filterContext.Result is ImageResult)
{
return;
}
string acceptEncoding = request.Headers["Accept-Encoding"];
if (string.IsNullOrEmpty(acceptEncoding)) return;
acceptEncoding = acceptEncoding.ToUpperInvariant();
HttpResponseBase response = filterContext.HttpContext.Response;
if (acceptEncoding.Contains("GZIP"))
{
response.AppendHeader("Content-encoding", "gzip");
response.Filter = new GZipStream(response.Filter, CompressionMode.Compress);
}
else if (acceptEncoding.Contains("DEFLATE"))
{
response.AppendHeader("Content-encoding", "deflate");
response.Filter = new DeflateStream(response.Filter, CompressionMode.Compress);
}
}
}