亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > ASP > 正文

Cookies 欺騙漏洞的防范方法(vbs+js 實現)

2024-05-04 11:08:38
字體:
來源:轉載
供稿:網友
考慮到 ASP 開發可以采用 vbs 和 js 兩種語言,這里同時提供兩種語言的程序代碼(雙語版?YY中……)
 
 
 
最后羅嗦一句,本人錄入這篇文章用的機器上沒有 ASP 環境,所以提供的代碼未能進行測試,對這一點本人深表歉意。如果大家發現了代碼中的任何問題,歡迎拍磚~本人皮厚~ 
一、攻擊原理 
Cookies 欺騙主要利用當前網絡上一些用戶管理系統將用戶登錄信息儲存在 Cookies 中這一不安全的做法進行攻擊,其攻擊方法相對于 SQL 注入漏洞等漏洞來說相對要“困難”一些,但還是很“傻瓜”。 
我們知道,一般的基于 Cookies 的用戶系統至少會在 Cookies 中儲存兩個變量:username 和 userlevel,其中 username 為用戶名,而 userlevel 為用戶的等級。當我們的瀏覽器訪問 ASP 頁面時,它會傳出類似 
GET /.../file.asp HTTP 1.0 
... 
Cookies: username=user&userlevel=1 
... 
的數據包,那么,我們只要知道了管理員的 username 和 userlevel 值(假設分別為 admin 和 5),便可以通過傳輸 
GET /.../file.asp HTTP 1.0 
... 
Cookies: username=admin&userlevel=5 
... 
來獲取管理員權限。很簡單是不是?然而,在這個漏洞被發現之前,幾乎所有的用戶管理系統都依賴于 Cookies。 
二、安全地儲存用戶信息 
既然 Cookies 是不安全的,而我們又必須把用戶登錄信息存儲下來,那么應該存儲在什么地方呢? 
我們注意到,在 ASP 中,除了 Cookies 外,還有 Session 可以儲存信息。Session 是儲存在服務器上的,不是客戶端隨隨便便就能夠更改的,所以具有極高的安全性。這樣,大家就可以把所有 Cookies 的代碼均換作 Session 了。 
三、長時間儲存用戶信息 
采用 Session 來保存用戶登錄信息,雖然擺脫了 Cookies 欺騙的問題,但是 Session 不能長期儲存(IIS 默認 Session 在用戶停止響應 20 分鐘后失效),于是產生了這一節所述的 Cookies + Session 混合存儲法。 
這一方法有兩個變種,第一種是在 Cookies 中儲存用戶名和密碼,當用戶訪問一個頁面時,先讀取 Session,如果有內容則以 Session 為準,否則讀取 Cookies,按照 Cookies 中提供的用戶名和密碼進行“不透明”的登錄一次,用以判斷 Cookies 中的內容是否合法,若合法再進而存入 Session 中。實現這一方法的代碼如下: 
vbs: 
復制代碼代碼如下:

<% 
Dim username, password 
username = Session("username") 
if username = "" then 
' Session 中沒有用戶登錄信息 
username = Request.Cookies("username") 
password = Request.Cookies("password") 
' 注意上面的兩句得到的 username 和 password 要進行 SQL 注入漏洞的防范(即過濾掉單引號“'”),這里略去 
if username = "" or password = "" then 
' 用戶沒有登錄 
... 
else 
' 這里假設已經創建了 conn 和 rs 對象 
rs.Open "SELECT TOP 1 * FROM [user] WHERE username='" & username & "' AND password='" & password & "'", conn, 1, 3 
if rs.eof then 
' Cookies 中的信息非法 
... 
else 
' Cookies 中的信息合法,自動登錄 
Session("username") = username 
... 
end if 
end if 
else 
' 用戶信息已經存在于 Session 中,直接讀取 
... 
end if 
%> 

js: 
復制代碼代碼如下:

<% 
var username, password; 
username = Session("username") + ""; 
if (username == "" || username == "undefined") { 
// Session 中沒有用戶信息 
username = Request.Cookies("username") + ""; 
password = Request.Cookies("password") + ""; 
// 注意上面的兩句得到的 username 和 password 要進行 SQL 注入漏洞的防范(即過濾掉單引號“'”),這里略去 
if (username == "" || username == "undefined" || password == "" || password == "undefined") { 
// 用戶沒有登錄 
... 

else { 
// 這里假設已經創建了 conn 和 rs 對象 
rs.Open("SELECT TOP 1 * FROM [user] WHERE username='" + username + "' AND password='" + password + "'", conn, 1, 3); 
if (rs.eof) { 
// Cookies 中的信息非法 
... 

else { 
// Cookies 中的信息合法,自動登錄 
Session("username") = username + ""; 
... 



else { 
// 用戶信息已經存在于 Session 中,直接讀取 
... 

%> 

但是這種方法對于用戶來說又不太安全,原因是瀏覽器每次訪問頁面時都會把 Cookies 傳輸過去,而包含密碼的 Cookies 一旦被他人獲取將導致用戶帳號被盜。對于這種情況,又出現了第二種方法,即在用戶信息數據庫中增加一個字段“verifycode”,在用戶登錄時,隨機產生一個長整型校驗值存入 verifycode 字段,并且將 username 和這個 verifycode 值而不是 password 存入 Cookies。而在驗證 Cookies 中的用戶信息時,也只驗證 username 和 verifycode。這種方法的好處在于,即使用戶的 Cookies 被黑客獲取,他也只能利用這個“臨時”產生的 verifycode 登錄,而無法獲得用戶的密碼。只要此用戶再一次使用用戶名和密碼登錄,這個 verifycode 值便會改變,黑客便無法通過原來的 verifycode 登入。 
這種方法的實現只需要在上述方法一的代碼上稍加改動。首先,在您的登錄程序中,在驗證通過存儲用戶信息的地方需要加上一段: 
vbs: 
復制代碼代碼如下:

<% 
Response.Cookies("verifycode") = int(rnd * 2100000000) 
%> 

js: 
復制代碼代碼如下:

<% 
Response.Cookies("verifycode") = Math.floor(Math.random() * 2100000000); 
%> 

然后,在上面提供的驗證代碼中把對 Cookies("password") 的驗證改為對 Cookies("verifycode") 的驗證即可。 
四、結論 
通過我們的分析以及處理,Cookies 欺騙漏洞已經被完全解決,從此,我們的 ASP 程序變得更加安全了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩视频在线| 91国产精品电影| 26uuu亚洲国产精品| 色综合色综合久久综合频道88| 久久视频这里只有精品| 亚洲欧美在线x视频| 操人视频在线观看欧美| 国产精品久久久久77777| 色偷偷噜噜噜亚洲男人的天堂| 中文字幕亚洲无线码在线一区| 91极品视频在线| www.亚洲男人天堂| 日本成人免费在线| 欧美黑人国产人伦爽爽爽| 91精品综合久久久久久五月天| 久久全国免费视频| 高清欧美一区二区三区| 国产精品日韩电影| 国产精品美女午夜av| 国产精品久久久久久久久粉嫩av| 国产精品日韩专区| 国产精品久久精品| www亚洲精品| 日韩女优在线播放| 97av在线播放| 国产精品美女午夜av| 亚洲免费一级电影| 亚洲免费视频在线观看| 91禁国产网站| 欧美日韩国产中文精品字幕自在自线| 国产国语videosex另类| 欧美激情成人在线视频| 亚洲国产天堂久久综合网| 日韩欧美福利视频| 日韩精品视频在线观看网址| 久久久久日韩精品久久久男男| 51精品在线观看| 亚洲视频777| 日本一区二区三区在线播放| 色综合久久精品亚洲国产| 成人黄色片网站| 日韩一中文字幕| 精品视频9999| 一区二区三区视频免费在线观看| 九九久久久久99精品| 精品国产精品三级精品av网址| 亚洲人成电影网站色www| 日韩精品中文在线观看| 亚洲天堂av电影| 国产精品久久久久久久7电影| 少妇高潮 亚洲精品| 色综合91久久精品中文字幕| 久久这里有精品| 性欧美激情精品| 欧美日韩激情网| 亚洲精品综合精品自拍| 亚洲国产精品嫩草影院久久| 26uuu另类亚洲欧美日本一| 久久久电影免费观看完整版| 欧美午夜性色大片在线观看| 精品国产美女在线| 日韩欧美一区二区在线| 久久69精品久久久久久国产越南| 国产精品一区二区久久久久| 日本一区二区三区在线播放| 欧美一级在线亚洲天堂| 色综合色综合久久综合频道88| 亚洲第一av网站| 亚洲精品第一国产综合精品| 亚洲欧美一区二区三区久久| 欧美日韩亚洲一区二区| 另类专区欧美制服同性| 精品一区二区三区电影| 久久成人精品电影| 成人做爰www免费看视频网站| 亚洲bt天天射| 欧美性videos高清精品| 亚洲黄色www网站| 亚洲天堂av在线免费观看| 欧美一级成年大片在线观看| 亚洲a在线观看| 成人黄色短视频在线观看| 国产成人久久精品| 国产精品狠色婷| 国产欧美 在线欧美| 日韩视频中文字幕| 狠狠色噜噜狠狠狠狠97| 亚洲成色777777女色窝| 亚洲日本中文字幕免费在线不卡| 欧美国产欧美亚洲国产日韩mv天天看完整| 性色av一区二区三区免费| 国产日韩亚洲欧美| 亚洲国产成人在线播放| 欧美国产高跟鞋裸体秀xxxhd| 91成人在线播放| 亚洲免费小视频| 国产精品久久久久不卡| 国产欧美精品在线播放| 国产精品一区二区久久精品| 欧美日韩国产区| 久久久亚洲网站| 欧美一级在线亚洲天堂| 91国偷自产一区二区三区的观看方式| 97久久超碰福利国产精品…| 国产欧美一区二区三区在线| 91精品视频在线免费观看| 69久久夜色精品国产7777| 欧美日韩国产中文精品字幕自在自线| 精品人伦一区二区三区蜜桃网站| 日韩欧美精品网站| 国产精品视频资源| 午夜欧美大片免费观看| 亚洲第一av网| 91免费在线视频| 国产精品第一页在线| 午夜精品在线观看| 久久99国产综合精品女同| 欧美一区二区三区免费视| 欧美成年人网站| 国产精品偷伦一区二区| 欧美日韩xxxxx| 欧美成人免费大片| 91高清免费在线观看| 久久色免费在线视频| 国产999精品久久久| 国产综合福利在线| 九九热这里只有精品免费看| 国产欧美久久久久久| 福利一区视频在线观看| 亚洲的天堂在线中文字幕| 国产99在线|中文| 91精品国产综合久久香蕉的用户体验| 成人网在线免费看| 在线观看国产精品91| 亚洲综合最新在线| 日韩成人在线电影网| 成人国内精品久久久久一区| 欧美亚洲伦理www| 青青久久av北条麻妃黑人| 91精品久久久久久久久青青| 精品日本美女福利在线观看| 亚洲福利在线观看| 色噜噜国产精品视频一区二区| 黑人狂躁日本妞一区二区三区| 97国产真实伦对白精彩视频8| 91在线无精精品一区二区| 国产自产女人91一区在线观看| 日韩中文av在线| 中文字幕日韩电影| 久久久久久亚洲精品中文字幕| 亚洲成人国产精品| 国产91ⅴ在线精品免费观看| 国产精品∨欧美精品v日韩精品| 97婷婷大伊香蕉精品视频| 欧洲亚洲免费在线| 亚洲欧美激情四射在线日| 国产精品久久久久aaaa九色| 久久99久久久久久久噜噜| 亚洲精品99久久久久| 一区三区二区视频| 国产精品久久久久久久久借妻| 国产日韩欧美中文在线播放| 精品国产户外野外| www国产精品视频|