国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - ASP.NET教程 - Asp.net中安全退出時清空Session或Cookie的實(shí)例代碼

Asp.net中安全退出時清空Session或Cookie的實(shí)例代碼

2020-04-06 12:12小離子 ASP.NET教程

網(wǎng)站中點(diǎn)擊退出,如果僅僅是重定向到登錄/出頁面,此時在瀏覽器地址欄中輸入登錄后的某個頁面地址如主頁,你會發(fā)現(xiàn)不用登錄就能訪問,這種退出并不安全了,下面通過本文給大家介紹安全退出時清空Session或Cookie的實(shí)例代碼

概覽:

網(wǎng)站中點(diǎn)擊退出,如果僅僅是重定向到登錄/出頁面,此時在瀏覽器地址欄中輸入登錄后的某個頁面地址如主頁,你會發(fā)現(xiàn)不用登錄就能訪問。這種所謂的退出并不是安全的。

那么怎樣做到安全退出呢?

那就是點(diǎn)擊退出后清空相應(yīng)的Session或Cookie。

清空Session的代碼:

?
1
2
Session.Clear();
Session.Abandon();

清除Cookie的正確代碼(假設(shè)Cookie名稱為UserInfo):

?
1
2
3
4
if (Request.Cookies["UserInfo"] != null)
{
Response.Cookies["UserInfo"].Expires = DateTime.Now.AddDays(-1);
}

如果需要清除所有Cookie,則遍歷:

?
1
2
3
4
for (int i = 0; i <Response.Cookies.Count; i++)
{
Response.Cookies[i].Expires = DateTime.Now.AddDays(-1);
}

清除Cookie的錯誤代碼(假設(shè)Cookie名稱為UserInfo):

?
1
2
3
4
if (Request.Cookies["UserInfo"] != null)
{
Response.Cookies.Remove("UserInfo");
}

你會發(fā)現(xiàn),這樣處理后,Cookie依然存在,為什么就是刪不掉呢?我們?nèi)タ纯?NET的HttpCookieCollection實(shí)現(xiàn)源碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
public void Remove(string name)
{
if (this._response != null)
{
this._response.BeforeCookieCollectionChange();
}
this.RemoveCookie(name);
if (this._response != null)
{
this._response.OnCookieCollectionChange();
}
}

這個操作在HttpCookieCollection這個集合里面刪除了cookie,當(dāng)服務(wù)器將數(shù)據(jù)傳輸?shù)娇蛻舳说臅r候,不會包含這個已經(jīng)在服務(wù)端刪除了的Cookie的任何信息,瀏覽器也就不會對它做任何改變(remove方法只是不讓服務(wù)器向客戶機(jī)發(fā)送那個被刪除的cookie,與此cookie留不留在客戶機(jī)里無關(guān))。所以cookie刪除不掉的情況就出現(xiàn)。

既然Response.Cookies.Remove沒有辦法實(shí)現(xiàn)我們需要的效果,為什么微軟還有留著呢,因?yàn)镃ookieCollection實(shí)現(xiàn)ICollection接口,romove是必須實(shí)現(xiàn)的方法,盡管它沒多大的實(shí)際價值。而集合的romove也應(yīng)該是這樣的實(shí)現(xiàn)方式,只不過微軟在寫MSDN的時候,描述得太不清楚了,給我們造成了不小的麻煩。

下面就總結(jié)下實(shí)現(xiàn)安全退出的幾種方式:

1).用Linkbutton,Button等服務(wù)器控件實(shí)現(xiàn)退出

這種方式最好處理:直接在服務(wù)器控件對應(yīng)的事件里編寫清空Session或Cookie的代碼即可。

2).用<a>注銷</a>等HTML標(biāo)記實(shí)現(xiàn)退出

對于<a></a>這個特殊標(biāo)記,可以這樣實(shí)現(xiàn): <a href="logout.aspx">注銷</a> ,在logout.aspx的Page_Load事件中編寫清空Session或Cookie的代碼即可。

對于<a></a>等HTML標(biāo)記,可以在HTML標(biāo)記的相應(yīng)client事件中用Js-Ajax,或者jQuery-Ajax,在一般處理程序(.ashx)中編寫清空Session或Cookie的代碼即可。

對于<a></a>等HTML標(biāo)記,還可以這樣:在當(dāng)前頁面添加一個服務(wù)器控件如Button,用div包含,并讓其隱藏(注意:隱藏不可見,不能通過服務(wù)器屬性Visible=False,只能通過設(shè)置div的display:none;來實(shí)現(xiàn)),在Button的服務(wù)器事件Cilck里編寫清空Session或Cookie的代碼;然后在HTML標(biāo)記的相應(yīng)client事件中用Js或者jQuery調(diào)用Button控件的Click事件即可(通過服務(wù)器屬性Visible=False設(shè)置Button隱藏,Js或者jQuery調(diào)用Button控件的Click事件將失效)。

以上所述是小編給大家介紹的Asp.net中安全退出時清空Session或Cookie的實(shí)例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對服務(wù)器之家網(wǎng)站的支持!

原文鏈接:http://www.cnblogs.com/Scl891004X/archive/2016/11/29/6114034.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩不卡在线 | 日韩亚洲视频 | 国产欧美日韩综合精品一区二区 | 久草最新 | 久久亚洲精品中文字幕 | 色片视频免费 | 精品久久久一 | 欧洲一区二区三区 | 黄色成人av | 国产露脸国语对白在线 | 亚洲国产精品视频一区二区三区 | 久久丁香| 91精品一区二区三区久久久久久 | 久久精品国产亚洲 | 久久久www成人免费无遮挡大片 | 日韩国产 | 久久久久久国产一级毛片高清版 | 91久久综合亚洲鲁鲁五月天 | 日韩欧美一区二区三区免费观看 | 91av精品| 精品成人 | 91精品一区二区三区久久久久久 | 美女国产精品 | 精品成人免费一区二区在线播放 | 久在线看 | 97久久精品 | 丝袜+亚洲+另类+欧美+变态 | 日韩精品一区二区三区精品av | 日韩欧美在线不卡 | 日韩欧美中文字幕在线视频 | 色综合久久久久 | 成人免费xxxxx在线视频软件 | 国内精品一区二区三区视频 | 欧美高清在线 | 久久九| 亚洲视频综合 | 91精品国产乱码久久久久久 | 欧美日韩一区在线 | 国产精品久久久久久久久福交 | 一区二区三区视频在线观看 | 欧美激情视频一区 |