HttpModuleをを使用してバックグラウンドサービスでのセッションへのアクセス

StackOverflow https://stackoverflow.com/questions/582222

  •  06-09-2019
  •  | 
  •  

質問

私は、セッションタイムアウトをチェックし、タイムアウトページ(ないログインページ)にユーザーをリダイレクトするasp.netでのバックグラウンドサービスを作成しようとしています。私のコードは次のようである。

public class SessionTimeoutModule : IHttpModule
{
    private static Timer timer;
    //Test value
    private const int interval = 1000 * 1 * 10;

    public void Init( HttpApplication application )
    {
        if ( timer == null )
        {
            timer = new Timer( new TimerCallback( CheckSessionTimeout ),
                         application.Context, 0, interval );
        }
    }

    private void CheckSessionTimeout( object sender )
    {
        HttpContext ctx = (HttpContext)sender;

        if ( ctx.Session != null && ctx.Session.IsNewSession )
        {
            var cookie = ctx.Request.Headers["Cookie"];
            if ( cookie != null )
            {
                if ( cookie.ToUpper().IndexOf( "ASP.NET_SESSIONID" ) >= 0 )
                {
                    ctx.Response.Redirect( "" );
                }
            }
        }
    }

    public void Dispose()
    {
        timer = null;
    }
}

ここでの問題は、私はCheckSessionTimeout方法でセッション値を取得することはできませんよということです。それは、常にnullです。どのようにここでセッションを取得することができます。

私はでこののソリューションを見てきましたが、それはdoesntの助けます。

役に立ちましたか?

解決

私はあなたがここで間違って軌道に乗っているんです。あなたは、このようなHttpModuleをを使用してバックグラウンドサービスを実装することはできません。あなたの周りに渡しているのHttpContextは、HTTPリクエストにバインドされている、と私はあなたが何をしようとしているようにあなたがそれを周りにおくべきではない、かなり確信しています。また、セッションのタイムアウトを検出したとしても、アクティブな要求せずに新しいページにユーザーをリダイレクトする方法はありません。
あなたはこれを見つけるかもしれません便利のスレッドます。

他のヒント

私はあなたのコードを修正した場合でも、あなたはエンドセッションを取得することはありません、ここで論理的間違いがあると思います。

あなたがセッションにアクセスできる場合は、

は、セッションIDを持つことになります。あなたはこの方法でタイムアウトで終了したセッションを取得することはできません。

たぶん、あなたは、Global.asaxの者のSession_Endを使用する必要があります。私はそれが役立つかわからない。

また、ここにあなたが見ることができるの中で、セッションIDがSession.Abandonまでに交換されていません。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top