黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 實現Session時間永久有效的方法

實現Session時間永久有效的方法

更新時間:2021-11-18 10:07:31 來源:動力節點 瀏覽1455次

原理:在B/S系統中,如果用戶在Session超時時間前與服務器進行了交互,那么將不會超時。所以我們只要模擬用戶在Session超時前和服務器進行交互就可以實現Session的永久有效。

具體實現:網路上有很多中方法實現了以上原理,從而實現了Session的永久有效。我也是參考了眾多方法,然后將我嘗試成功的一個方法記錄一下。

1. 將如下JavaScript代碼放置在系統使用中一直顯示的頁面中,如在框架頁面中,你可以將如下代碼放置在Banner框架、Bottom框架、左側一直顯示的菜單框架,或者是一個隱藏框架中。如果是非框架頁面,那么可以放置在不會被用戶關閉的頁面中,如主菜單頁面。這樣的目的是保證頁面始終存在,從而其中的JavaScript代碼可以是中在執行。

<!-- 用于從服務器上請求.aspx文件的JavaScript腳本塊; -->
 < script language = " javascript "  id = " KeepSessionAliveScriptBlock " >
 </ script >
 < script language = " javascript " >
    // 用于循環調用服務器.aspx文件的JavaScript函數;
     keepSessionAlive();
 </ script >

2. 在.js文件中添加keepSessionAlive()函數,函數體如下:

 /**
   *summary: 通過定時請求服務器的某個頁面(.aspx)文件來保證Session不會超時。
 *created: liguozhu(李國珠)
   *modifty,content: [修改者,修改內容說明]
   *
   *created time: 2007-11-22
   */
    function  keepSessionAlive()
    {
        document.all["KeepSessionAliveScriptBlock"].src = "/BJAssess/YearAssessSubSystem/Resource/WebForm3.aspx?RandStr="+Math.random();
        //這里的RandStr=Math.random只是為了讓每次back.src的值不同,防止同一地址刷新無效的情況
        window.setTimeout("keepSessionAlive()",30000); 
   }

這里document.all["KeepSessionAliveScriptBlock"] 這里引用了頁面上<script language="javascript" id="KeepSessionAliveScriptBlock"></script>的程序塊對象,其中的src屬性指向的是需要打開的文件。一般src 應該指向的是.js文件,這個效果就是將js文件中的內容加入到程序塊中,然后再進行執行。如:src = "testJS.js", 而testJS.js文件中如果有一句window.alert("Life Is Good!");,那么執行了代碼后頁面會彈出"Life Is Good"的信息提示框。其實javascript程序塊的src屬性并不會在意引用的是否是.js文件,它僅僅是打開指定的文件,然后將文件內容按照JavaScript的方式進行執行,當然如果你打開文件的內容中不是合法的JavaScript內容,那么將不執行內容。

這里設置src的頁面路徑需要注意的是為了防止各個調用頁面的路徑不同,這里建議采用自上而下的路徑方式,如例子中的路徑就是BJAssess項目,然后一級級的找到需要調用的.aspx頁面文件。為了放置IE讀取緩存的情況,這里在讀取.aspx頁面文件的URL中增加一個隨機數。

window.setTimeout用于定時(例子中設置的是3000毫秒,即半分鐘)重復執行keepSessionAlive()一次,這里的時間可以自行設置為小于Session超時的任何時間。這個每隔半分鐘的請求WebForm3.aspx頁面的操作就是實現了前面“原理”中描述模擬用戶操作和服務器進行交互,從而保證Session不超時的功能。

3. 在對應的路徑下建立一個用于請求的.aspx頁面文件,例子中是WebForm3.aspx。這里需要在HTML源碼模式將所有HTML代碼刪除,因為如果不刪除這些代碼,ASP.NET在解析.aspx文件后會產生一個完整的HTML頁面代碼,這樣如果再嵌到前面的<script language="javascript"></script>腳本塊中就會由于<html>, <head>, <body>

等標簽出現重復而保錯,在IE中顯示的錯誤是“語法錯誤”。寫到這里,可能會有人說既然不能產生完整的HTML頁面代碼,那么為什么不直接使用.ascx(用戶自定義Web控件)呢?直接請求.ascx是不行的,我目前想到的原因是“你在瀏覽器中是無法直接請求一個.ascx文件的”,如果你在瀏覽器中直接請求.ascx那么瀏覽器會返回無法訪問的錯誤。所以你在javascript.src = "xxx.ascx"文件的時候,實際上是請求不成功的。

到此為止實現永久Session的步驟就完成了。這里還需要特別說明一下,在網絡上看到有些帖子說需要在請求的頁面,如:.aspx頁面中調用代碼Session("xxx") = "xxx"。其中Session("xxx")是隨便的一個Session值,目的是為了調用Session來保證Session不過期,實際上這個操作是沒有必要的,原因是(在.NET Framework 1.1的環境下)在請求系統頁面的時候,如最常見的是請求Login.aspx界面,這個時候針對此次回話的SessionID和Session就已經生成了,其他所有的Session("xxx")操作都是對于這個Session列表中具體Item的操作。所以只要你與服務器進行了交互,那么服務器就會驗證你的SessionID,對應的Session是否過期,如果沒有,那么就延后過期時間。

以上就是關于“實現Session時間永久有效的方法”的介紹,如果您想了解更多相關知識,不妨來關注一下動力節點的Spring Session教程,里面的課程內容豐富,適合沒有基礎的小白學習,希望對大家能夠有所幫助。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 午夜精品久视频在线观看 | 欧美精彩视频在线观看 | 成人午夜免费视频免费看 | 手机午夜看片 | 69国产成人综合久久精 | 国产1卡二卡3卡四卡免费 | 免费色网站 | 中文字幕在线网 | 日本午夜网站 | 亚洲最大激情网 | 欧美亚洲另类色国产综合 | 国产成人精品一区 | 久久精品亚洲欧美日韩久久 | 成人看片黄在线观看 | 成人免费视频在线播放 | 国内自拍欧美 | 美女一级a毛片免费观看 | 国产一级第一级毛片 | 男女免费视频网站 | 上色天天综合网 | 久久成人国产精品 | 成人欧美 | 免费看一级黄色片 | 91短视频在线观看免费最新 | 日日操夜夜操狠狠操 | 少妇激情av一区二区 | 最近中文字幕免费完整国语 | 成人免费观看国产高清 | 在线免费福利 | 一区二区三区在线观看视频 | 黄网站色在线视频免费观看 | 2022国产成人福利精品视频 | 久久成人网18网站 | 色综合久久加勒比高清88 | 欧美亚洲国产成人综合在线 | 国产成人三级经典中文 | 成人五月网 | 一级毛片视频在线观看 | 天堂网2021天堂手机版 | 嘿嘿嘿视频在线观看网站 | 国产一卡二卡 |