Я пытаюсь заставить [ 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);
}
}
}