質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.78%

Internet Explorerで、モードレスウィンドウでのセッションの保持方法

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 2,532

score 34

いつもお世話になっております。
Internet Explorerで、モードレスウィンドウを開いている時の
セッションの保持方法についてご教授いただきたいです。
以下のような状況です。

環境:

ブラウザ:Internet Explorer 11
サーバOS:windows Server 2012
APサーバ:IIS
言語:C# (.NET Framework 4.5.2 ASPX)
セッション:InProcで保持する
javascript:jQuery 1.11
社内イントラネット

画面構成(関連部分のみ抜粋):

ログイン画面

一覧画面に画面遷移

window.openで詳細画面を表示(window名を指定)

操作手順:

  1. ログイン画面でログイン
    → 一覧画面に遷移
  2. 一覧画面で詳細表示ボタンクリック
    →window.openで詳細画面を表示
    以降、この詳細画面のウィンドウは閉じない
  3. サーバ側のIISを再起動する。
    →InProcのためセッション情報がクリアされる
  4. 再度ログイン画面でログイン
    → 一覧画面に遷移
    新しいセッションIDが払い出される
  5. 一覧画面で詳細表示ボタンクリック
    →window.openで詳細画面を表示
    →手順2で開いたウィンドウに対して、詳細画面を開こうとする
    →サーバへのリクエストにおいて、手順2の時のセッションIDが送信される

問題点:

手順5でウィンドウを開いた時、手順2の時のセッションIDが
サーバ側に送信される。
サーバ側は手順3で再起動しているため、手順2のセッションIDを
管理しておらず、新規セッションIDだとみなされる。
(Session.IsNewSession==true)
新規セッションだとログイン画面を表示してしまう。

質問:

Internet Explorerでモードレスウィンドウを開くと、セッションID
(Cookie)が保持されるのですが、ウィンドウを閉じない限り
保持し続けられるようです。

このモードレスウィンドウのセッションIDを更新する方法は無いでしょうか。
その他、この問題を解決する良い方法があれば、ご教授いただけないでしょうか。

現在考えているのは、ログイン後の初回の一覧画面表示時に、
モードレスウィンドウに対して「自画面を閉じる」スクリプトを埋め込んだ
HTMLを呼び出すことです。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • SurferOnWww

    2017/07/27 09:21

    ASP.NET の話なら ASP.NET のタグをつけていただくよう願いします。

    キャンセル

回答 2

checkベストアンサー

0

asp.net の session の話なら質問に書いてあるようなことはできません。

そもそもの目的は何ですか? それがわかると何か代案とかが出てくるかもしれません。(追記)その際は認証方式が何かを書いてください。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/07/27 12:22 編集

    ご回答ありがとうございます。
    パスワード入力画面でのフォーム認証です。

    目的は上記操作で、モードレスウインドウで詳細画面を表示しようとして、ログイン画面が表示されることの回避です。
    また、記載を省略しましたが、このような画面がたくさんあります。

    よって、ログイン時にこれら画面を一括で閉じる案を検討しました。
    他に良案があればご教示ください。

    キャンセル

  • 2017/07/27 13:53

    そのフォーム認証というのは質問者さんの独自実装ですか? asp.net 標準のフォーム認証で認証チケットを認証クッキー(セッションクッキーとは別物)に入れて送るものなら、一旦認証を受ければログイン画面にリダイレクトされるようなことはないはずです。

    キャンセル

  • 2017/07/27 14:12

    独自のものです。
    また、global.asaxに手を入れており、Session.IsNewSessionで新規セッションか判定しています。

    そもそもの認証部分で好ましくないところがあるのですが、そこを改修すると全体に影響がでてしまうので実施できないです。

    キャンセル

0

Sessionの変更ができないとのことだったため、
当初予定通りログイン時にウィンドウを閉じる方法で対応することとなりました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.78%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る