【轉】session 會話期+tomcat常用設置

http://news.newhua.com/news1/Skills_System/2009/319/0931910354983H11G1FF6GI5JBEJ371B4H62BF1FD1A8IK39F7B25582.html

1. 在tomcat——>conf——>servler.xml文件中定義:

<Context path="/test" docBase="/test"   defaultSessionTimeOut="3600" isWARExpanded="true"   isWARValidated="false" isInvokerEnabled="true"   isWorkDirPersistent="false"/> defaultSessionTimeOut="3600"

2. 在web.xml中定義:

<session-config> <session-timeout>20</session-timeout> </session-config>

3. 在程序中定義:

session.setMaxInactiveInterval(30*60);

 

http://blog.csdn.net/vastskyjoe/archive/2009/01/06/3723280.aspx

 

別人的測試:http://sdyouyun.javaeye.com/blog/146275

http://blog.chinaunix.net/u/3984/showart_359018.html

 

使用Session機制一些常見的問題開發者在線  更新時間:2007-11-23作者:龔勳 來源:賽迪網本文關鍵詞:問題 session

 

1、session在何時被創建

一個常見的誤解是以爲session在有客戶端訪問時就被創建,然而事實是直到某server端程序調用

HttpServletRequest.getSession(true)這樣的語句時才被創建,注意如果JSP沒有顯示的使用 %@page session="false"% 關閉session,則JSP文件在編譯成Servlet時將會自動加上這樣一條語句HttpSession session = HttpServletRequest.getSession(true);這也是JSP中隱含的session對象的來歷。

由於session會消耗內存資源,因此,如果不打算使用session,應該在所有的JSP中關閉它。

2、session何時被刪除

綜合前面的討論,session在下列情況下被刪除a.程序調用HttpSession.invalidate();或b.距離上一次收到客戶端發送的session id時間間隔超過了session的超時設置;或c.服務器進程被停止(非持久session)

3、如何做到在瀏覽器關閉時刪除session

嚴格的講,做不到這一點。可以做一點努力的辦法是在所有的客戶端頁面裏使用javascript代碼window.oncolose來監視瀏覽器的關閉動作,然後向服務器發送一個請求來刪除session。但是對於瀏覽器崩潰或者強行殺死進程這些非常規手段仍然無能爲力。

4、有個HttpSessionListener是怎麼回事

你可以創建這樣的listener去監控session的創建和銷燬事件,使得在發生這樣的事件時你可以做一些相應的工作。注意是session的創建和銷 毀動作觸發listener,而不是相反。類似的與HttpSession有關的listener還有HttpSessionBindingListener,HttpSessionActivationListener和HttpSessionAttributeListener。

5、存放在session中的對象必須是可序列化的嗎

不是必需 的。要求對象可序列化只是爲了session能夠在集羣中被複制或者能夠持久保存或者在必要時server能夠暫時把session交換出內存。在 Weblogic Server的session中放置一個不可序列化的對象在控制檯上會收到一個警告。我所用過的某個iPlanet版本如果session中有不可序列化的對象,在session銷燬時會有一個Exception,很奇怪。

6、如何才能正確的應付客戶端禁止cookie的可能性

對所有的URL使用URL重寫,包括超鏈接,form的action,和重定向的URL,具體做法參見(http://e-docs.bea.com/wls/docs70/webapp/sessions.html#100770)。

7、開兩個瀏覽器窗口訪問應用程序會使用同一個session還是不同的session

參見第三小節對cookie的討論,對session來說是隻認id不認人,因此不同的瀏覽器,不同的窗口打開方式以及不同的cookie存儲方式都會對這個問題的答案有影響。

8、如何防止用戶打開兩個瀏覽器窗口操作導致的session混亂

這個問題與防止表單多次提交是類似的,可以通過設置客戶端的令牌來解決。就是在服務器每次生成一個不同的id返回給客戶端,同時保存在session裏,客 戶端提交表單時必須把這個id也返回服務器,程序首先比較返回的id與保存在session裏的值是否一致,如果不一致則說明本次操作已經被提交過了。可以參看《J2EE核心模式》關於表示層模式的部分。需要注意的是對於使用javascript window.open打開的窗口,一般不設置這個id, 或者使用單獨的id,以防主窗口無法操作,建議不要再window.open打開的窗口裏做修改操作,這樣就可以不用設置。

9、爲什麼在Weblogic Server中改變session的值後要重新調用一次session.setValue做這個動作主要是爲了在集羣環境中提示Weblogic Server session中的值發生了改變,需要向其他服務器進程複製新的session值。

10、爲什麼session不見了

排除session正常失效的因素之外,服務器本身的可能性應該是微乎其微的,雖然筆者在iPlanet6SP1加若干補丁的Solaris版本上倒也遇到 過;瀏覽器插件的可能性次之,筆者也遇到過3721插件造成的問題;理論上防火牆或者代理服務器在cookie處理上也有可能會出現問題。

出現這一問題的大部分原因都是程序的錯誤,最常見的就是在一個應用程序中去訪問另外一個應用程序。

http://www.builder.com.cn/2007/1123/650439.shtml

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章