asp.net中session的原理及應(yīng)用詳解
更新時間:2012年11月20日 16:34:43 作者:
Session是一種Web會話中的常用狀態(tài)之一,Session提供了一種把信息保存在服務(wù)器內(nèi)存中的方式。他能儲存任何數(shù)據(jù)類型,包含自定義對象,本文將詳細(xì)介紹asp.net中session的原理及應(yīng)用,需要的朋友可以參考下
Session簡介丶特性
--------------------------------------------------------------------------------
1.Session是一種Web會話中的常用狀態(tài)之一。
2.Session提供了一種把信息保存在服務(wù)器內(nèi)存中的方式。他能儲存任何數(shù)據(jù)類型,包含自定義對象。
3.每個客戶端的Seesion是獨(dú)立存儲的。
4.在整個會話過程中,只要SessionID的cookie不丟失,都會保存Session信息的。
5.Session不能跨進(jìn)程訪問,只能由該會話的用戶訪問。應(yīng)為提取Session數(shù)據(jù)的id標(biāo)識是以Cookie的方式保存到訪問者瀏覽器的緩存里的。
6.當(dāng)會話終止,或過期時,服務(wù)器就清除Session對象。
7.Session常用于保存登錄用戶的ID.
8.Session保存的數(shù)據(jù)是跨頁面全局型的。
--------------------------------------------------------------------------------
Session的使用
--------------------------------------------------------------------------------
這里我寫入一個例子,便于下面闡述。
<head runat="server">
<title></title>
<script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
function getSessionClick(action) { //這個函數(shù)是為了知道哪一個提交按鈕被點(diǎn)擊
$("#hidlgc").val(""); //清空隱藏值
$("#hidlgc").val(action); //給隱藏控件賦值
}
</script>
</head>
<body>
<form id="form1" method="post" action="MySession.aspx">
<table>
<tr>
<td>賬號:</td><td><input type="text" name="txtUid" /></td>`
</tr>
<tr>
<td>密碼:</td><td><input type="password" name="txtPwd" /></td>
</tr>
<tr>
<td colspan="2">
<input type="hidden" value="" id="hidlgc" name="hidlgclick" />
<input onclick="getSessionClick('lgclick')" type="submit" value="登錄" />
<input type="submit" onclick="getSessionClick('getSession')" value="獲取session" />
<input type="submit" onclick="getSessionClick('backLg')" value="退出登錄" />
</td>
</tr>
</table>
</form>
</body>
protected void Page_Load(object sender, EventArgs e)
{
//把用戶id寫入session中
if (Request.Form["hidlgclick"] == "lgclick")
{
if(Request.Form["txtUid"].ToString()=="admin"&&Request.Form["txtUid"].ToString()=="admin") //判斷用戶登錄
{
Session["userName"] = Request.Form["txtUid"].ToString(); //把用戶id保存到session中
Response.Write(Session["userName"].ToString()+"---點(diǎn)擊登錄"); //獲取session,并寫入頁面
}
}
//獲取Session
if (Request.Form["hidlgclick"] == "getSession")
{
if (Session["userName"] != null)
{
Response.Write(Session["userName"].ToString() + "---點(diǎn)擊獲取session"); //獲取session,并寫入頁面
}
}
//取消當(dāng)前會話,相當(dāng)于注銷(退出登錄)。
if (Request.Form["hidlgclick"] == "backLg")
{
Session.Abandon();
}
}
<system.web>
<sessionState timeout="40"></sessionState> <!---設(shè)置session的過期時間,時間以分鐘為單位-->
Session原理(根據(jù)上面例子闡述)
--------------------------------------------------------------------------------
一、session是怎么存儲,提取的?
1.在服務(wù)器端有一個session池,用來存儲每個用戶提交session中的數(shù)據(jù),Session對于每一個客戶端(或者說瀏覽器實(shí)例)是“人手一份”,用戶首次與Web服務(wù)器建立連接的時候,服務(wù)器會給用戶分發(fā)一個SessionID作為標(biāo)識。SessionID是一個由24個字符組成的隨機(jī)字符串。用戶每次提交頁面,瀏覽器都會把這個SessionID包含在HTTP頭中提交給Web服務(wù)器,這樣Web服務(wù)器就能區(qū)分當(dāng)前請求頁面的是哪一個客戶端,而這個SessionID是一cookie的方式保存的在客戶端的內(nèi)存中的,如果想要得到Session池中的數(shù)據(jù),服務(wù)器就會根據(jù)客戶端提交的唯一SessionID標(biāo)識給出相應(yīng)的數(shù)據(jù)返回。
2.輸入正確的賬號密碼,點(diǎn)擊登錄,頁面就會輸出 “admin --- 點(diǎn)擊登錄”
二、Session池中每個客戶端的數(shù)據(jù)是怎么存儲的?
1.存儲在Session池中的數(shù)據(jù)是全局型的數(shù)據(jù),可以跨頁面訪問,每個SessionID中只存儲唯一的數(shù)據(jù),如:首先你這樣設(shè)定:session["userName"]="admin",然后你在會話還沒結(jié)束的session還沒過期的情況下,你又設(shè)定:session["userName"]="123";這樣這個SessionID沒變,然而Session池中的數(shù)據(jù)則被覆蓋。此時session["userName"]的值就是“123”,而不是其它。
2.Session池中的數(shù)據(jù)不能跨進(jìn)程訪問。如:打開login.aspx頁面寫入session[“userName”]="admin";然后login頁面不關(guān)閉,即此會話不結(jié)束,在這是你再在另外一個瀏覽器中打開一個login.aspx頁面則session["userName"]=null
3.輸入賬號密碼,點(diǎn)擊登錄頁面輸出 “admin --- 點(diǎn)擊登錄” ,如果緊接著點(diǎn)擊獲取session按鈕,則頁面只輸出"admin--- 點(diǎn)擊獲取session",如果頁面不關(guān)閉,打開另外一個瀏覽器,點(diǎn)擊獲取session按鈕,則頁面沒法應(yīng)。
三丶session的聲明周期與銷毀
1.session存儲數(shù)據(jù)計(jì)時是滾動計(jì)時方式。具體是這樣的,如果你打開寫入session,從寫入開始,此頁面如果一直沒有提交操作,則默認(rèn)時間是20分鐘,20分鐘后session被服務(wù)器自動銷毀,如過有提交操作,服務(wù)器會從提交后重新計(jì)時以此類推,直至設(shè)定時間內(nèi)銷毀。
2.可以設(shè)置session的銷毀時間。上面代碼有提到。
四丶session中保存的數(shù)據(jù)是在服務(wù)端的,而每個用戶如進(jìn)行登錄操作,都要進(jìn)行session數(shù)據(jù)寫入,所以建議慎用session,就是少用。
--------------------------------------------------------------------------------
1.Session是一種Web會話中的常用狀態(tài)之一。
2.Session提供了一種把信息保存在服務(wù)器內(nèi)存中的方式。他能儲存任何數(shù)據(jù)類型,包含自定義對象。
3.每個客戶端的Seesion是獨(dú)立存儲的。
4.在整個會話過程中,只要SessionID的cookie不丟失,都會保存Session信息的。
5.Session不能跨進(jìn)程訪問,只能由該會話的用戶訪問。應(yīng)為提取Session數(shù)據(jù)的id標(biāo)識是以Cookie的方式保存到訪問者瀏覽器的緩存里的。
6.當(dāng)會話終止,或過期時,服務(wù)器就清除Session對象。
7.Session常用于保存登錄用戶的ID.
8.Session保存的數(shù)據(jù)是跨頁面全局型的。
--------------------------------------------------------------------------------
Session的使用
--------------------------------------------------------------------------------
這里我寫入一個例子,便于下面闡述。
復(fù)制代碼 代碼如下:
<head runat="server">
<title></title>
<script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>
<script type="text/javascript">
function getSessionClick(action) { //這個函數(shù)是為了知道哪一個提交按鈕被點(diǎn)擊
$("#hidlgc").val(""); //清空隱藏值
$("#hidlgc").val(action); //給隱藏控件賦值
}
</script>
</head>
<body>
<form id="form1" method="post" action="MySession.aspx">
<table>
<tr>
<td>賬號:</td><td><input type="text" name="txtUid" /></td>`
</tr>
<tr>
<td>密碼:</td><td><input type="password" name="txtPwd" /></td>
</tr>
<tr>
<td colspan="2">
<input type="hidden" value="" id="hidlgc" name="hidlgclick" />
<input onclick="getSessionClick('lgclick')" type="submit" value="登錄" />
<input type="submit" onclick="getSessionClick('getSession')" value="獲取session" />
<input type="submit" onclick="getSessionClick('backLg')" value="退出登錄" />
</td>
</tr>
</table>
</form>
</body>
復(fù)制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
//把用戶id寫入session中
if (Request.Form["hidlgclick"] == "lgclick")
{
if(Request.Form["txtUid"].ToString()=="admin"&&Request.Form["txtUid"].ToString()=="admin") //判斷用戶登錄
{
Session["userName"] = Request.Form["txtUid"].ToString(); //把用戶id保存到session中
Response.Write(Session["userName"].ToString()+"---點(diǎn)擊登錄"); //獲取session,并寫入頁面
}
}
//獲取Session
if (Request.Form["hidlgclick"] == "getSession")
{
if (Session["userName"] != null)
{
Response.Write(Session["userName"].ToString() + "---點(diǎn)擊獲取session"); //獲取session,并寫入頁面
}
}
//取消當(dāng)前會話,相當(dāng)于注銷(退出登錄)。
if (Request.Form["hidlgclick"] == "backLg")
{
Session.Abandon();
}
}
復(fù)制代碼 代碼如下:
<system.web>
<sessionState timeout="40"></sessionState> <!---設(shè)置session的過期時間,時間以分鐘為單位-->
Session原理(根據(jù)上面例子闡述)
--------------------------------------------------------------------------------
一、session是怎么存儲,提取的?
1.在服務(wù)器端有一個session池,用來存儲每個用戶提交session中的數(shù)據(jù),Session對于每一個客戶端(或者說瀏覽器實(shí)例)是“人手一份”,用戶首次與Web服務(wù)器建立連接的時候,服務(wù)器會給用戶分發(fā)一個SessionID作為標(biāo)識。SessionID是一個由24個字符組成的隨機(jī)字符串。用戶每次提交頁面,瀏覽器都會把這個SessionID包含在HTTP頭中提交給Web服務(wù)器,這樣Web服務(wù)器就能區(qū)分當(dāng)前請求頁面的是哪一個客戶端,而這個SessionID是一cookie的方式保存的在客戶端的內(nèi)存中的,如果想要得到Session池中的數(shù)據(jù),服務(wù)器就會根據(jù)客戶端提交的唯一SessionID標(biāo)識給出相應(yīng)的數(shù)據(jù)返回。
2.輸入正確的賬號密碼,點(diǎn)擊登錄,頁面就會輸出 “admin --- 點(diǎn)擊登錄”
二、Session池中每個客戶端的數(shù)據(jù)是怎么存儲的?
1.存儲在Session池中的數(shù)據(jù)是全局型的數(shù)據(jù),可以跨頁面訪問,每個SessionID中只存儲唯一的數(shù)據(jù),如:首先你這樣設(shè)定:session["userName"]="admin",然后你在會話還沒結(jié)束的session還沒過期的情況下,你又設(shè)定:session["userName"]="123";這樣這個SessionID沒變,然而Session池中的數(shù)據(jù)則被覆蓋。此時session["userName"]的值就是“123”,而不是其它。
2.Session池中的數(shù)據(jù)不能跨進(jìn)程訪問。如:打開login.aspx頁面寫入session[“userName”]="admin";然后login頁面不關(guān)閉,即此會話不結(jié)束,在這是你再在另外一個瀏覽器中打開一個login.aspx頁面則session["userName"]=null
3.輸入賬號密碼,點(diǎn)擊登錄頁面輸出 “admin --- 點(diǎn)擊登錄” ,如果緊接著點(diǎn)擊獲取session按鈕,則頁面只輸出"admin--- 點(diǎn)擊獲取session",如果頁面不關(guān)閉,打開另外一個瀏覽器,點(diǎn)擊獲取session按鈕,則頁面沒法應(yīng)。
三丶session的聲明周期與銷毀
1.session存儲數(shù)據(jù)計(jì)時是滾動計(jì)時方式。具體是這樣的,如果你打開寫入session,從寫入開始,此頁面如果一直沒有提交操作,則默認(rèn)時間是20分鐘,20分鐘后session被服務(wù)器自動銷毀,如過有提交操作,服務(wù)器會從提交后重新計(jì)時以此類推,直至設(shè)定時間內(nèi)銷毀。
2.可以設(shè)置session的銷毀時間。上面代碼有提到。
四丶session中保存的數(shù)據(jù)是在服務(wù)端的,而每個用戶如進(jìn)行登錄操作,都要進(jìn)行session數(shù)據(jù)寫入,所以建議慎用session,就是少用。
相關(guān)文章
.NET的Ajax請求數(shù)據(jù)提交實(shí)例
這篇文章主要介紹了.NET的Ajax請求數(shù)據(jù)提交實(shí)例,較為詳細(xì)的分析了Ajax請求、數(shù)據(jù)的提交以及參數(shù)的傳遞技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-01-01
談?wù)勅绾卧贏SP.NET Core中實(shí)現(xiàn)CORS跨域
本篇文章主要介紹了如何在ASP.NET Core中實(shí)現(xiàn)CORS跨域,CORS主要是解決Ajax跨域限制的問題,有興趣的可以了解一下。2016-12-12
asp.net core 集成swagger ui的原理解析
本文主要講解了如何對API進(jìn)行分組,這里僅僅是舉了一個按照API功能進(jìn)行分組的例子,其實(shí)在實(shí)際開發(fā)中,要按照何種方式分組,可以按照需求靈活定義,比如按照API版本進(jìn)行分組2021-10-10
ASP.NET Core利用Jaeger實(shí)現(xiàn)分布式追蹤詳解
這篇文章主要給大家介紹了關(guān)于ASP.NET Core利用Jaeger實(shí)現(xiàn)分布式追蹤的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用ASP.NET Core具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
.net core webapi 大文件上傳到wwwroot文件夾的操作代碼
這篇文章主要介紹了.net core webapi 大文件上傳到wwwroot文件夾的操作代碼,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-12-12
JavaScript驗(yàn)證用戶輸入的是字符或數(shù)字及ASCII Chart應(yīng)用
我們可以根據(jù)onkeydown事件的event.keyCode即是ASCII Chart來判斷字符或數(shù)字等,本文提供了相關(guān)鍵盤key對應(yīng)的ASCII碼,以供用戶使用是參考及使用onpaste事件只能輸入字符和數(shù)字防止粘貼等的,感興趣的朋友可以了解下2013-01-01

