0

私はMVC4にかなり慣れていません。サーバーからクライアントに大量のデータを交換するアプリケーションがあります。すべてのメソッドは、jQuery AJAX 呼び出しを介して実行されます。時間/帯域幅を抑えるために、コントローラー メソッドで圧縮を処理するカスタム属性を実装しました。

public class CompressFilter : ActionFilterAttribute
{
    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        HttpRequestBase request = filterContext.HttpContext.Request;

        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);
        }
    }
}

かなり標準的で、問題なく動作します。ただし、カスタム属性を追加して、セッションがまだ存在することを確認し、そうでない場合は(ログアウト機能を介して)ログインページにリダイレクトしようとしています。2 番目の属性は次のとおりです。

public class SessionExpireFilter : ActionFilterAttribute {

    public override void OnActionExecuting( ActionExecutingContext filterContext )
    {
        HttpContext ctx = HttpContext.Current;

        // check if session is supported
        if ( ctx.Session != null ) {

            // check if a new session id was generated
            if ( ctx.Session.IsNewSession ) {

                // If it says it is a new session, but an existing cookie exists, then it must
                // have timed out
                string sessionCookie = ctx.Request.Headers[ "Cookie" ];
                if ( ( null != sessionCookie ) && ( sessionCookie.IndexOf ( "ASP.NET_SessionId" ) >= 0 ) ) {

                    ctx.Response.Redirect ( "~/Home/Logout" );
                    //filterContext.Result = new RedirectResult("~/Home/Logout");
                }
            }
        }

        base.OnActionExecuting ( filterContext );
    }
}

問題は、これにより次のエラーが生成されることです。

「HTTP ヘッダーが送信された後、サーバーはヘッダーを追加できません。」

に置き換えてみましctx.Response.Redirect......たがfilterContext.Result = new RedirectResult("~/Home/Logout")、これによりエラーは削除されますが、クライアントに実際にリダイレクトするようには指示されません。

運が悪いのでオンラインで検索してみましたが、解決する能力が限界に来ています。誰かが私を正しい方向に向けることができますか、または上記のいずれかを処理するためのより良い方法についてアドバイスしてください。

4

0 に答える 0