C# と VB.NET の質問掲示板
ASP.NET、C++/CLI、Java 何でもどうぞ
掲示板トップ
C# と VB.NET 入門
新規作成
利用方法
ツリー表示
トピック表示
ランキング
記事検索
過去ログ
ログ内検索
キーワードを複数指定する場合は 半角スペース で区切ってください。
検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
[返信]をクリックすると返信ページへ移動します。
キーワード
/
検索条件
/
(AND)
(OR)
検索範囲
/
(現在のログ)
(全過去ログ)
(過去ログ1)
(過去ログ2)
(過去ログ3)
(過去ログ4)
(過去ログ5)
(過去ログ6)
(過去ログ7)
(過去ログ8)
(過去ログ9)
(過去ログ10)
(過去ログ11)
(過去ログ12)
(過去ログ13)
(過去ログ14)
(過去ログ15)
(過去ログ16)
(過去ログ17)
(過去ログ18)
(過去ログ19)
(過去ログ20)
(過去ログ21)
(過去ログ22)
(過去ログ23)
(過去ログ24)
(過去ログ25)
(過去ログ26)
(過去ログ27)
(過去ログ28)
(過去ログ29)
(過去ログ30)
(過去ログ31)
(過去ログ32)
(過去ログ33)
(過去ログ34)
(過去ログ35)
(過去ログ36)
(過去ログ37)
(過去ログ38)
(過去ログ39)
(過去ログ40)
(過去ログ41)
(過去ログ42)
(過去ログ43)
(過去ログ44)
(過去ログ45)
(過去ログ46)
(過去ログ47)
(過去ログ48)
(過去ログ49)
(過去ログ50)
(過去ログ51)
(過去ログ52)
(過去ログ53)
(過去ログ54)
(過去ログ55)
(過去ログ56)
(過去ログ57)
(過去ログ58)
(過去ログ59)
(過去ログ60)
(過去ログ61)
(過去ログ62)
(過去ログ63)
(過去ログ64)
(過去ログ65)
(過去ログ66)
(過去ログ67)
(過去ログ68)
(過去ログ69)
(過去ログ70)
(過去ログ71)
(過去ログ72)
(過去ログ73)
(過去ログ74)
(過去ログ75)
(過去ログ76)
(過去ログ77)
(過去ログ78)
(過去ログ79)
(過去ログ80)
(過去ログ81)
(過去ログ82)
(過去ログ83)
(過去ログ84)
(過去ログ85)
(過去ログ86)
(過去ログ87)
(過去ログ88)
(過去ログ89)
(過去ログ90)
(過去ログ91)
(過去ログ92)
(過去ログ93)
(過去ログ94)
(過去ログ95)
(過去ログ96)
(過去ログ97)
(過去ログ98)
(過去ログ99)
(過去ログ100)
(過去ログ101)
(過去ログ102)
(過去ログ103)
(過去ログ104)
(過去ログ105)
(過去ログ106)
(過去ログ107)
(過去ログ108)
(過去ログ109)
(過去ログ110)
(過去ログ111)
(過去ログ112)
(過去ログ113)
(過去ログ114)
(過去ログ115)
(過去ログ116)
(過去ログ117)
(過去ログ118)
(過去ログ119)
(過去ログ120)
(過去ログ121)
(過去ログ122)
(過去ログ123)
(過去ログ124)
(過去ログ125)
(過去ログ126)
(過去ログ127)
(過去ログ128)
(過去ログ129)
(過去ログ130)
(過去ログ131)
(過去ログ132)
(過去ログ133)
(過去ログ134)
(過去ログ135)
(過去ログ136)
(過去ログ137)
(過去ログ138)
(過去ログ139)
(過去ログ140)
(過去ログ141)
(過去ログ142)
(過去ログ143)
(過去ログ144)
(過去ログ145)
(過去ログ146)
(過去ログ147)
(過去ログ148)
(過去ログ149)
(過去ログ150)
(過去ログ151)
(過去ログ152)
(過去ログ153)
(過去ログ154)
(過去ログ155)
(過去ログ156)
(過去ログ157)
(過去ログ158)
(過去ログ159)
(過去ログ160)
(過去ログ161)
(過去ログ162)
(過去ログ163)
(過去ログ164)
(過去ログ165)
(過去ログ166)
(過去ログ167)
(過去ログ168)
(過去ログ169)
(過去ログ170)
(過去ログ171)
(過去ログ172)
(過去ログ173)
(過去ログ174)
(過去ログ175)
(過去ログ176)
(過去ログ177)
(過去ログ178)
(過去ログ179)
強調表示
/
ON
(自動リンクOFF)
結果表示件数
/
20件
30件
40件
50件
100件
記事No検索
/
ON
大文字と小文字を区別する
No.82972 の関連記事表示
ヒット / 9件
(1-9 を表示)
<<
0
>>
■82972
ASP.NETで、セッションタイムアウトになる条件
□投稿者/ あさ -
(2017/02/23(Thu) 15:07:47)
分類:[.NET 全般]
お世話になります。
Windows10、ASP.NET(VB)、.NET Framework4.6、ローカルIISで開発しています。
WebサーバーOSはWindowsServer2012R2です。
Webページのタイムアウトについてです。
IISマネージャーの[セッション状態]で、タイムアウト=デフォルトで「20分」になっています。
Webページに、TextBox、Buttonがあるとします。
Webページにログインして、そのまま何もせず放置すれば、20分経過するとセッションが破棄、ログアウトの状態になり、
Buttonを押しても正常に実行されないと思います。
ここで質問です。
20分以内に、TextBox(AutoPostBack=False)の内容を追加したり、削ったりしても、
20分以内にButtonを押さない限りは、20分後にタイムアウトになってしまうようなのですが、
これは正常な反応ということでよろしいでしょうか。
20分以内にButtonを押すか、TextBoxのAutoPostBack=Trueにしなければ、
TextBoxの中身をどんなにいじっても、
それはアイドル状態とみなされるという認識でよろしいでしょうか。
よろしくお願いします。
親記事 /過去ログ141より /
関連記事表示
削除チェック/
■82974
Re[1]: ASP.NETで、セッションタイムアウトになる条件
□投稿者/ WebSurfer -
(2017/02/23(Thu) 16:09:31)
■
No82972
(あさ さん) に返信
ASP.NET の場合は、セッションの「タイムアウト」状態とフォーム認証の「ログアウト」状態は違います。
まず、そこの理解はいいでしょうか?
質問者さんの理解に曖昧な点があれば以下の記事を読んでください。
セッションタイムアウトとログアウト
http://surferonwww.info/BlogEngine/post/2013/06/29/session-timeout-and-logout.aspx
> Webページにログインして、そのまま何もせず放置すれば、20分経過するとセッションが破棄、
> ログアウトの状態になり、Buttonを押しても正常に実行されないと思います。
何をもって「正常」と言われているのか不明ですが・・・
セッションがタイムアウト(デフォルトで 20 分)しているが、認証チケットはまだ有効な場合(その
ページに匿名アクセスが許可されていれば認証チケットは関係ありませんが)、Button クリックでポ
ストバックがかかってそのページが要求され、サーバーはその要求を受けて処理します。
ただし、その処理の過程でセッションのデータを使っている場合、セッション状態が破棄されているこ
とによる影響はあるとは思いますが。でも、その可能性があることを考えて質問者さんがそのページを
作れば、セッション状態が破棄されていても、それなりに「正常」処理することはできるかも。
認証チケットが期限切れの場合、セッションがタイムアウトしているか否かに関係なく、そのページに
匿名アクセスが許可されていなければ、Login ページにリダイレクトされると思います。(普通に作れ
ばの話ですが)
> 20分以内に、TextBox(AutoPostBack=False)の内容を追加したり、削ったりしても、
> 20分以内にButtonを押さない限りは、20分後にタイムアウトになってしまうようなのですが、
> これは正常な反応ということでよろしいでしょうか。
そうです。
TextBox(AutoPostBack=False)の場合は、ブラウザでテキストボックスの内容をどのように変更しよう
とそれはブラウザ側だけの話で、Web サーバーは何も関知しません。
セッションの有効期限を延ばすことができるのは Web サーバーのみですので、それは「正常な反応」です。
TextBox の AutoPostBack プロパティを true にすれば、ブラウザ上でテキストボックスの内容を変更
してフォーカスをはずせばポストバックがかかって、サーバーが要求を受けるので、その際セッション
タイムアウトが延長されます。
要するに、サーバーが何の要求も受けない状態がセッションタイムアウトに設定した時間以上続くとセ
ッション状態は破棄されるということです。
記事No.82972 のレス /過去ログ141より /
関連記事表示
削除チェック/
■83002
Re[2]: ASP.NETで、セッションタイムアウトになる条件
□投稿者/ あさ -
(2017/02/25(Sat) 19:21:40)
■
No82974
(WebSurfer さん) に返信
> ■
No82972
(あさ さん) に返信
ありがとうございます。
> ASP.NET の場合は、セッションの「タイムアウト」状態とフォーム認証の「ログアウト」状態は違います。
> まず、そこの理解はいいでしょうか?
記事を拝読しました。
現在開発しているシステムは、一時保育に関するものでして、
会員は各お子様、
連絡先は親御様のメールアドレス、になっています。
同じ親御様であれば、複数のお子様がいても、メールアドレスは共通です。
このため、メールアドレスを一意のユーザーIDに使用できません。
このことが理由で、現状では、フォーム認証ではなく、独自のプログラムコードでの認証を行なっています。
データベースに認証情報を保持して、問い合わせ、ログインしたらSession変数でユーザーのIDを保持しています。
Session変数がNothingでなければログイン中、Nothingであればログアウト中、という状態です。
この方法ですと、セッションがタイムアウトした場合、Session変数もNothingになり、
実質的にログアウト状態になります。
> ただし、その処理の過程でセッションのデータを使っている場合、セッション状態が破棄されているこ
> とによる影響はあるとは思いますが。でも、その可能性があることを考えて質問者さんがそのページを
> 作れば、セッション状態が破棄されていても、それなりに「正常」処理することはできるかも。
そうですね。
うちの現状に照らし合わせて考えてみますと、ボタンを押した時の処理に、Session変数も使用しているため、
タイムアウトでSession変数が破棄されますと、処理時にエラーになります。
Session変数がNothingの場合の処理の分岐を、プログラムに追加します。
> 要するに、サーバーが何の要求も受けない状態がセッションタイムアウトに設定した時間以上続くとセ
> ッション状態は破棄されるということです。
ありがとうございます。
ページによっては、IISのタイムアウト設定(デフォルト20分)が短い場合があります。
この場合、ページのロード時に、Session.timeout=数値、を設定すれば、
このページに関しては、IISの設定値よりも優先されるようです。
http://d.hatena.ne.jp/aspx/20071226/1198654988
記事No.82972 のレス /過去ログ141より /
関連記事表示
削除チェック/
■83006
Re[3]: ASP.NETで、セッションタイムアウトになる条件
□投稿者/ WebSurfer -
(2017/02/25(Sat) 20:14:58)
■
No83002
(あさ さん) に返信
> 現状では、フォーム認証ではなく、独自のプログラムコードでの認証を行なっています。
それ、最初の質問の一行目に書きましょうね。何なのって感じです。
記事No.82972 のレス /過去ログ141より /
関連記事表示
削除チェック/
■83014
Re[4]: ASP.NETで、セッションタイムアウトになる条件
□投稿者/ あさ -
(2017/02/26(Sun) 11:05:53)
■
No83006
(WebSurfer さん) に返信
> それ、最初の質問の一行目に書きましょうね。何なのって感じです。
失礼しました。
フォーム認証という仕組みの存在について、
よく知らなかったものでして。
今後気を付けます。
記事No.82972 のレス / END /過去ログ141より /
関連記事表示
削除チェック/
■83015
Re[5]: ASP.NETで、セッションタイムアウトになる条件
□投稿者/ WebSurfer -
(2017/02/26(Sun) 12:44:07)
■
No83014
(あさ さん) に返信
> フォーム認証という仕組みの存在について、よく知らなかったものでして。
ASP.NET 標準のフォーム認証を使って質問者さんのやりたいことができないか検討された
でしょうか?
「よく知らなかった」ということは検討されてないように思えますが、もしそうであれば
一度検討してみることをお勧めします。
メールアドレスを ID に使用するのは困るということのようですが、標準のフォーム認証
でその必要はないはずです。
(ASP.NET Identity で一時メールアドレスを ID に使う時期があったようですが、自分が
最近使い始めた Visual Studio 2015 Community Update 3 では、そのテンプレートで自動
生成される ASP.NET Identity ベースのフォーム認証を使うインターネットアプリを見ると、
昔ながらのユーザーが決めた独自 ID を使うようになっています。それに加えてメールアド
レスも登録できるようです)
記事No.82972 のレス / END /過去ログ141より /
関連記事表示
削除チェック/
■83016
Re[6]: ASP.NETで、セッションタイムアウトになる条件
□投稿者/ あさ -
(2017/02/26(Sun) 17:38:17)
■
No83015
(WebSurfer さん) に返信
> 「よく知らなかった」ということは検討されてないように思えますが、もしそうであれば
> 一度検討してみることをお勧めします。
>
> メールアドレスを ID に使用するのは困るということのようですが、標準のフォーム認証
> でその必要はないはずです。
>
> (ASP.NET Identity で一時メールアドレスを ID に使う時期があったようですが、自分が
> 最近使い始めた Visual Studio 2015 Community Update 3 では、そのテンプレートで自動
> 生成される ASP.NET Identity ベースのフォーム認証を使うインターネットアプリを見ると、
> 昔ながらのユーザーが決めた独自 ID を使うようになっています。それに加えてメールアド
> レスも登録できるようです)
ありがとうございます。
検討してみます。
記事No.82972 のレス / END /過去ログ141より /
関連記事表示
削除チェック/
■83031
Re[7]: ASP.NETで、セッションタイムアウトになる条件
□投稿者/ WebSurfer -
(2017/02/27(Mon) 21:51:20)
■
No83016
(あさ さん) に返信
先のレスで、
> ASP.NET Identity で一時メールアドレスを ID に使う時期があったようですが、自分が
> 最近使い始めた Visual Studio 2015 Community Update 3 では、そのテンプレートで自動
> 生成される ASP.NET Identity ベースのフォーム認証を使うインターネットアプリを見ると、
> 昔ながらのユーザーが決めた独自 ID を使うようになっています。
と書きましたが、それは Web サイトプロジェクトのテンプレートで作った時の話で、もう少
し調べてみたら Web アプリケーションプロジェクトのテンプレートで作ると、ID は email
になってました。(Web Forms, MVC 共に)
登録・ログイン関係のコードもかなり違ってました。
何故違うのか理由不明ですが、自分が調べた限り Web サイトプロジェクトのコードであれば、
従来どおりの ID(email アドレスでないユーザー名)とパスワードでユーザー認証には問題
なかったです。
まだ調べ切れていませんが、コードの書き方しだいで(たぶん、ASP.NET Identity 2 の新機
能を使わなければ)従来どおりの ID が使えるような気がします。
記事No.82972 のレス /過去ログ141より /
関連記事表示
削除チェック/
■83032
Re[8]: ASP.NETで、セッションタイムアウトになる条件
□投稿者/ WebSurfer -
(2017/02/27(Mon) 21:52:17)
解決済みマークを付け忘れました。すみません
記事No.82972 のレス / END /過去ログ141より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-