ASP.Net中無刷新執行Session身份驗證

来源:http://www.cnblogs.com/aspnetjia/archive/2016/01/29/5167917.html
-Advertisement-
Play Games

在寫一個客戶的B/S結構應用程式時,突然發現一個技巧,不知道是否是MS的一個BUG,給相關的有研究的朋友原先考慮寫一個檢查Session的類,Session失效後,必須轉向登陸頁面,可每一個調用該類的頁面,在不同的WEB路徑下,所以轉到登陸頁面的URL都不同,每個頁面都要調用和設置登陸頁面路徑,所以


 

在寫一個客戶的B/S結構應用程式時,突然發現一個技巧,不知道是否是MS的一個BUG,給相關的有研究的朋友原先考慮寫一個檢查Session的類,Session失效後,必須轉向登陸頁面,可每一個調用該類的頁面,在不同的WEB路徑下,所以轉到登陸頁面的URL都不同,每個頁面都要調用和設置登陸頁面路徑,所以實際應用就放棄了這一想法後來考慮到不如寫一個檢查Session失效的頁面,由客戶端每一秒都刷新一下,就可以在一個頁面中調用,但通過FRAME嵌入該ASPX老時有請求發出,不太好看,雖然該頁面是隱藏的.再後來,想想,就用一個頁面,使用無刷新技術,去請求該失效Session的頁面就可以了,此處的無刷新技術使用了xmlhttp對象,沒有使用WEBService技術.(由於客戶的BS系統,使用FRAME框架,最上層的頁面是顯示軟體名稱,用戶登陸信息的,所以調用就放在該頁面中).

讓我們來看看代碼,主要是客戶端的JavaScript腳本程式

<scriptlanguage="javascript">
varidx=0;
functionChkSession()
{
varHttp=newActiveXObject("Microsoft.XMLHTTP");
Http.open("GET","ChkSessionOut.aspx",false);//檢查Session失效的頁面
Http.send();
varstr=Http.responseText;//執行ASPX後的返回結果
//idx++
//document.all("ConvertResult").innerHTML=str+idx;
if(str=="notnull")
{
//alert(str);
}
else
{
alert("會話值跟蹤時間超時,請重新登錄...");//這段代碼一直沒有運行,往下看,你就知道了
location.href="longin.aspx";
}
window.setTimeout(‘ChkSession()‘,1000);//每一秒鐘,請求一次ChkSessionOut.aspx
}
</script>

 


這段CODE,我放在<HEAD></HEAD>標簽之間,然後在BODY載入時,調用該函數,如下:

 


<BODYonload="ChkSession();">

ChkSessionOut.aspx.cs的代碼如下ChkSessionOut.aspx文件中的HTML標簽全部被我刪除,這樣一來執行下麵的代碼,就只有結果的輸出了

privatevoidPage_Load(objectsender,System.EventArgse)
{
if(Session["sUserID"]==null)
{
Response.Write("isnull");
return;
}
else
{
Response.Write("notnull");
return;
}
}

 

 

為了測試以上程式,我將WEB.Config的內容更改,將SESSION設置段,改成一分鐘後失效WEB.Config文件的一部分,設置一分鐘後失效SESSION的地方,如下:

<sessionStatemode="InProc"stateConnectionString="tcpip=127.0.0.1:42424"sqlConnectionString="datasource=127.0.0.1;Trusted_Connection=yes"cookieless="false"timeout="1"/>


然後我運行代碼,我特地在原來的IE上,使用菜單新打開一個IE視窗,為保證他們是檢查同一個SESSION,在地址中輸入ChkSessionOut.aspx,程式運行後,發現秘密了,一分鐘後,我點刷新ChkSessionOut.aspx的頁面,居然輸出notnull,我想到,對了,我每秒都在向這個頁面發請求,所以沒失效的原因,然後我將有無刷新技術的頁面關閉,過一分鐘後,發現輸出isnull,說明Session失效了,這個發現好,我吃了一驚!想到VS.NET好好好,它就是一個好工具,哈哈!我的環境IIS5.0,Win2000,VS.Net2003然後我有設置30秒自動請求,無刷新技術的主頁面不關,SESSION不失效,一關閉還是1分種後就失效,考慮到了1分鐘/30秒是整數,設置成50秒,無刷新技術的主頁面不關,它過1分種,失效了!哈哈,完全明白了!1分鐘/50秒非整數,所以失效

轉載自:http://www.aspnetjia.com


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如圖是效果圖,第一個按鈕當按下時彈出一個自定義的Dialog,第二個和第三個分別是ProgressBar,只是簡單的改變了樣式第1個ProgressBar是逆時針方向,第2 個時順時針方向 如下是主代碼package com.demo.sb.main;import com.demo.suibian....
  • 昨天開始寫代碼,把數據插入到mysql資料庫中,但是怎麼也沒辦法插入,上網搜,最後的辦法是在phpmyadmin中插入數據後將它轉換為php語句,最後如下: //$sql = "INSERT INTO `stu` ( `sno`, `sname`, `password`, `parentpd`, `
  • 這篇文章主要介紹了在mysql中使用一條sql語句插入多條數據,效率非常高,但是原理其實很簡單,希望對大家有所幫助 假如有一個數據表A: id name title addtime 如果需要插入n條數據 : 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 $tim
  • 關於芒果的許可權控制說白了就是定義Role(角色)來控制對資料庫進行的操作(調用的方法比如查詢方法find)。系統內置的Role分為以下幾大類:Database User Roles這個是針對非系統資料庫和部分系統表的角色組Database Administration Roles可以操作所有資料庫C...
  • 最新的PHP7 MySQL5.6 httpd2.4 ,手把手教你如何源碼安裝LAMP,如何配置相應環境
  • 講述如何在Winform界面中使用FontAwesome字體庫
  • 不知道有沒有朋友像我一樣會遇到這樣一個問題: 在網上購買 .NET 空間,由於虛擬主機的限制,你並不能把某個目錄設為一個獨立的應用,或者一些價格比較高的空間,雖然可以設置,但數量也是有限的。這個問題導致了在給網站擴展獨立功能的時候,比較被動,或者想在一個網站下跑幾個不同功能的應用,也很麻煩。 不過,
  • 一列數的規則如下: 1、1、2、3、5、8、13、21、34...... 求第30位數是多少, 用遞歸演算法實現。 代碼: public class MainClass { public static void Main() { Console.WriteLine(Foo(30)); } public
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...