Вопрос

У нас есть довольно распространенный код, который работал нормально:

public class CompressionFilterAttribute : ActionFilterAttribute
{
    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        HttpRequestBase request = filterContext.HttpContext.Request;
        if (request.IsAjaxRequest())
            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 WhitespaceFilter(new GZipStream(response.Filter, CompressionMode.Compress));
        }
        else if (acceptEncoding.Contains("DEFLATE"))
        {
             response.AppendHeader("Content-encoding", "deflate");
             response.Filter =  new WhitespaceFilter(new DeflateStream(response.Filter, CompressionMode.Compress));
        }
    }
}

Теперь я пытаюсь использовать Response.Flush() предоставлять доступ к части страницы, улучшать пользовательский опыт.При таком сценарии, когда response.Filter изменяется при каждой операции записи, становится ясно, что страница должна быть доставлена немедленно.Как я могу заставить свое приложение записывать данные в промежуточный поток, затем сжимать его, а затем отправлять в Response.Filter?

Это было полезно?

Решение

Пока это кажется неразрешимым, поскольку asp.net использует один и тот же поток для ввода и вывода для фильтров.

Другие советы

Я не думаю, что это выполнимо, но если вам нужно улучшить производительность и пользовательский опыт, то вы можете сделать следующее:

1- Используйте сжатие IIS, не нужно изобретать велосипед 2- Используйте кэширование выходных данных для действий, содержимое которых не будет часто меняться.3. Используйте частичный рендеринг, сначала вы выводите наиболее важные части своей страницы, а затем отправляете Ajax-запросы для загрузки остального содержимого страницы, таким образом, вы можете доставлять страницу частями

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top