大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

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

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

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

原理:在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教程,里面的課程內容豐富,適合沒有基礎的小白學習,希望對大家能夠有所幫助。

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

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 免费网站日本永久免费观看 | 奇米第一色 | 精品久久免费视频 | 久草看片 | 欧美日本一区二区 | 久久精品国产久精国产 | 亚洲欧美日韩在线精品2021 | 精品久久久久亚洲 | 真实国产乱弄免费视频 | 日韩中文字幕精品视频在线 | 日韩一区二区三区不卡视频 | 97精品国产97久久久久久 | 9久热这里只有精品视频在线观看 | 爆操日本美女 | 草草伊人 | 一级做性色a爱片久久片 | 亚洲欧美中文日韩二区一区 | 欧美精品在线免费观看 | 高清国产一区二区三区 | 毛片一级在线 | 日本高清专区一区二无线 | 国产精品1区 | 国产福利视频一区美女 | 91福利视频合集 | 在线a人片免费观看国产 | 夜夜干天天操 | 久久精品国产亚洲网站 | 欧美激情_区二区三区 | 国产69精品久久久久999小说 | 久久黄色一级视频 | 欧美日韩中字 | 最新香蕉97超级碰碰碰碰碰久 | 青青草一区二区免费精品 | 日本高清免费不卡毛片 | 国产一区二区三区亚洲欧美 | 猫咪视频成人永久免费观看 | 午夜性爽视频男人的天堂在线 | 国产综合精品一区二区 | 好吊妞人成免费视频观看 | 91国内视频 | 一级毛片特级毛片黄毛片 |