<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 188,comments - 176,trackbacks - 0

    首先談一下對session對象在web開發中的創建以及sessionId生成并返回客戶端的運行機制.

    session對象當客戶端首次訪問時,創建一個新的session對象.并同時生成一個sessionId,并在此次響應中將sessionId以響應報文的方式些回客戶端瀏覽器內存或以重寫url方式送回客戶端,來保持整個會話,只要sever端的這個session對象沒有銷毀,以后再調用request.getSession()時就直接根據客戶端的sessionId來檢索server端生成的session對象并返回,不會再次去新建,除非根據此sessionId沒有檢索到session對象.

    下面是在IE下測試,因為IE6.0的一個BUG就是IE的隱私設置即使是阻止所有cookie時,也還是會以會話cookie來保存sessionId.所以下面都是以會話cookie來討論的,

    (1)在server沒有關閉,并在session對象銷毀時間內,當客戶端再次來請求server端的servlet或jsp時,將會將在第一次請求時生成的sessionId并附帶在請求信息頭中并向server端發送,server端收到sessionId后根據此sessionId會去搜索(此過程是透明的)server對應的session對象并直接返回這個session對象,此時不會重新去建立一個新的session對象.

    (2)當server關閉(之前產生的session對象也就消亡了),或session對象過了其銷毀時間后,瀏覽器窗口不關,并在本瀏覽器窗口再次去請求sever端的servlet和jsp時,此時同樣會將sessionId(server關閉或session銷毀時生成的sessionId)發送到server端,server根據sessionId去找其對應的session對象,但此時session對象已經不存在,此時會重新生成一個新的session對象,并生成新的sessionId并同樣將這個新生成的sessionId以響應報文的形式送到瀏覽器內存中.

    (3)當server沒有關閉,并session對象在其銷毀時間內,當請求一個jsp頁面回客戶端后,關閉此瀏覽器窗口,此時其內存中的sessionId也就隨之銷毀,在重新去請求sever端的servlet或jsp時,會重新生成一個sessionId給客戶端瀏覽器,并存在瀏覽內存中.

    上面的理論在servlet中測試都是成立的,下面談一下在struts框架下進行上面的測試時的不同的地方.

    先簡要說下測試程序的流程:

    客戶端請求index.do--->進入server端的IndexAction--->轉向login.jsp頁面----->請求login.do----->進入server端的LoginAction.


    首先說明:IndexAction中沒有去產生session對象,login.jsp中設置<%@ page session="false"%>.

    (1)環境servlet + jsp:
    在sevlet+jsp測試跟蹤時,在index.do進入IndexAction后轉向login.jsp時,此時瀏覽器內存中是沒有會話cookie的,那么在login.jsp上請求login.do進入LoginAction后,用request.getCookies()測試時,其值是為null的!結果是穩合的,因為從始置終沒有產生過session嘛!

    (2)環境struts + jsp:
    在struts+jsp測試跟蹤時,跟上面的流程一樣,開始想結果也應該是一樣的,但經過調試后發現結果卻不是所想的那樣.在login.do進入LoginActoin后用,用request.getCookies()測試時,發現其值不為null,即其有name和value,開始很不理解,因為根本就沒有創建過session對象,哪來的會話cookie值呢.但是結果有,那么想著此時瀏覽器內存中也就應該有會話cookie,問題就在這里!從哪里來的?

    后來經過仔細考慮后,想到struts中的特點,我們自己寫的Action類是繼承struts的Action的,而且之前是經過struts的中央控制器ActionServlet來控制轉向的,所以我想肯定是在程序進入我自己寫的IndexAction之前,struts框架中的代碼肯定已經創建了session對象并已經生成了sessionId.于是就找到相關書籍查看了ActionServlet工作流程以及調用哪些類,看了之后果然在其中看到了HttpSession session = request.getSession();這樣一句話!于是答案也就明了了.

    *大家知道struts的ActionServlet類中在接收到我們客戶端的請求(*.do)后(之前會做一系列初始化工作),并不是直接去處理我們的請求并調用相應的Action(我們寫的如IndexAction),而是將處理工作交給RequestProcessor類,其process方法中會調用一系列的方法來完成相應的請求處理和轉向操作.其中有一個方法引起了我的關注,就是processLocale()方法.

    Struts框架:RequestProcess類中的processLocale()方法原型如下:

    protected void processLocale(HttpServletRequest request,
            HttpServletResponse response) {
            // Are we configured to select the Locale automatically?
            if (!moduleConfig.getControllerConfig().getLocale()) {
                return;
            }

            // Has a Locale already been selected?
            HttpSession session = request.getSession();

            if (session.getAttribute(Globals.LOCALE_KEY) != null) {
                return;
            }

            // Use the Locale returned by the servlet container (if any)
            Locale locale = request.getLocale();

            if (locale != null) {
                if (log.isDebugEnabled()) {
                    log.debug(" Setting user locale '" + locale + "'");
                }

                session.setAttribute(Globals.LOCALE_KEY, locale);
            }
        }

    此類在struts-config.xml配置文件中有對應的配置項:  <controller locale="true"></controller> 其缺省狀態locale屬性的值為true,也就會調用processLocale方法,并在第一次請求時創建session對象和生成sessionId.但改為false后,在第一次請求到達ActionServlet后不會調用processLocale方法,也就不會生成session對象了.

    結果也就出來了,在struts應用中,*.do到達server端后經過ActionServlet后轉想我們自己寫的IndexAction之前, <controller locale="true"></controller>(缺省狀態) 時,就已經產生了session對象和sessionId,這是struts框架類中生成的,即使我們在IndexAction中寫上HttpSession session = request.getSession();其也是RequestProcess類中的processLocale()方法生成的,此時其session的isNew也還是true,因為還沒有返回客戶端,其是新創建的,那么按照上面的流程,當在login.jsp上通過login.do進入LoginAction后,其request.getCookies()固然也就有值了!并且其值是RequestProcess類中的processLocale()方法產生session對象時生成的.

    如果我們在struts-config.xml中加上<controller locale="false"></controller> 時,此時如果再根據上面的流程來跟蹤程序,并在LoginAction用request.getCookies()測試時,其值是為null的,當然在IndexAction寫上HttpSession session = request.getSession();時其是進入IndexAction時新創建的,isNew也是true.





    posted on 2007-05-28 18:36 cheng 閱讀(1855) 評論(5)  編輯  收藏 所屬分類: Struts

    FeedBack:
    # re: struts中的session對象創建和控制
    2007-05-29 11:00 | wuchuanzi
    嗯,有意思  回復  更多評論
      
    # re: struts中的session對象創建和控制
    2007-05-29 15:59 | Dragon_sxw
    嘗試了一下,失敗,孫的書上寫的是<controller>local屬性默認為false  回復  更多評論
      
    # re: struts中的session對象創建和控制
    2007-05-29 23:03 | cheng
    樓上的朋友可以自己寫例子測試下,我測試的結果是:
    struts-config.xml中默認的是會產生session對象,
    即<controller locale="true"></controller> 當改為false時,就沒有產生session對象(在進入我們自己寫的Action之前)
      回復  更多評論
      
    # re: struts中的session對象創建和控制[未登錄]
    2008-02-29 16:25 | aa
    HttpSession session = request.getSession(); 這個就是為了存放值啊。不放session里 放什么地方啊!  回復  更多評論
      
    # re: struts中的session對象創建和控制
    2008-02-29 17:13 | cheng
    對呀,是放在session中的,只是在struts環境中,我這個上下文中,session的產生是在程序進入LoginAction之前就產生了。  回復  更多評論
      
    主站蜘蛛池模板: 亚洲情a成黄在线观看动漫尤物| 亚洲熟妇无码一区二区三区| 亚色九九九全国免费视频| 亚洲另类无码一区二区三区| 亚洲国产成人精品久久久国产成人一区二区三区综 | 日韩在线播放全免费| 最新亚洲人成无码网站| 国产精品亚洲A∨天堂不卡| 成人女人A级毛片免费软件| 有码人妻在线免费看片| 久久亚洲精品成人无码网站| 免费在线不卡视频| 中国xxxxx高清免费看视频| 色窝窝亚洲AV网在线观看| 亚洲av无码成人黄网站在线观看| 四虎成人免费大片在线| 18禁超污无遮挡无码免费网站| 亚洲色偷偷综合亚洲av78| 亚洲成AV人片在线观看无码| 在线观看免费亚洲| 精品成在人线AV无码免费看| 一级一黄在线观看视频免费| 亚洲男人天堂2022| 亚洲短视频男人的影院| 亚洲一区二区三区乱码A| 99视频在线精品免费观看6| 日本免费一区二区久久人人澡| 真正全免费视频a毛片| 亚洲国产av高清无码| 亚洲AV日韩AV永久无码免下载 | 久久久久国色AV免费观看性色 | 99久久精品毛片免费播放| 亚洲欧洲国产综合AV无码久久| 亚洲av日韩av不卡在线观看| 亚洲?v无码国产在丝袜线观看 | 国内精品免费麻豆网站91麻豆 | 99久久99热精品免费观看国产| 九九九精品视频免费| 亚洲a∨无码一区二区| 国产精品亚洲片夜色在线| 亚洲成AV人片高潮喷水|