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

首頁 > 編程 > ASP > 正文

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

2024-05-04 11:07:38
字體:
來源:轉載
供稿:網友
一、攻擊原理

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 程序變得更加安全了。

2007-08-05 20:37 寫作開始
2007-08-05 21:14 第一版完成

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美老少配视频| 日韩电影中文字幕在线| 在线观看精品国产视频| 91精品国产色综合| 成人国内精品久久久久一区| 日韩电影视频免费| 欧美一级片久久久久久久| 91国偷自产一区二区三区的观看方式| 韩国国内大量揄拍精品视频| 91精品国产高清久久久久久| 国产精品欧美激情在线播放| 亚洲欧洲在线看| 日韩精品免费在线观看| 国产精品高清在线观看| 国产精品成人av性教育| 色综合亚洲精品激情狠狠| 亚洲一区二区三区视频| 欧美激情国内偷拍| 日本欧美爱爱爱| 97视频人免费观看| 国产日韩欧美在线观看| 欧美激情综合色| 中文字幕九色91在线| 亚洲精品久久久久中文字幕欢迎你| 97视频在线免费观看| 最近2019中文免费高清视频观看www99| 欧美一级免费看| 精品国产一区二区三区久久| 国产欧美日韩免费看aⅴ视频| 久久福利网址导航| 欧美成人精品xxx| 欧美国产日韩一区二区三区| 国产成人精品免费久久久久| 在线播放国产精品| 深夜福利91大全| 日韩性xxxx爱| 亚洲一区av在线播放| 欧美日韩成人在线视频| 国产丝袜精品第一页| 国产精品va在线播放| 久久精品国亚洲| 国产小视频91| 成人免费观看a| 欧美国产日本高清在线| 亚洲四色影视在线观看| 国产亚洲精品成人av久久ww| 国产日韩专区在线| 九九视频直播综合网| 日韩国产在线播放| 国产精品久久久久久久久影视| 亚洲片在线资源| 亚洲毛片在线免费观看| 国产精品福利网| 日韩在线视频观看正片免费网站| 性色av一区二区三区| 亚洲美女精品久久| 久久久女女女女999久久| www.xxxx欧美| 国产精品三级网站| 欧美天天综合色影久久精品| 国产成人精品久久二区二区91| 成人免费视频网址| 91av视频在线免费观看| 精品久久久久久国产91| 久久久久久久久久av| 国产精品久久久久久久久久久久久久| 欧美麻豆久久久久久中文| 国产精品吊钟奶在线| 国产精品网站大全| 久久综合国产精品台湾中文娱乐网| 亚洲欧美国内爽妇网| 国产免费成人av| 国产伊人精品在线| 亚洲另类激情图| 日韩视频免费中文字幕| 91精品国产一区| 亚洲一级一级97网| 国产精品一区av| 国语自产在线不卡| 亚洲第五色综合网| 美女性感视频久久久| 日本精品中文字幕| 97激碰免费视频| 精品国产一区二区三区久久| 91精品免费视频| 日韩高清av一区二区三区| 国产精品视频在线播放| 在线观看不卡av| 91精品国产91久久久| 欧美成人精品在线播放| 欧美色videos| 一区二区欧美亚洲| 亚洲老司机av| 91精品国产综合久久香蕉最新版| 国产精品极品美女粉嫩高清在线| 亚洲欧洲日产国码av系列天堂| 麻豆一区二区在线观看| 久久久久久久久久久91| 精品久久久久久中文字幕一区奶水| 国产精品海角社区在线观看| 欧美俄罗斯性视频| 国产成人高潮免费观看精品| 色综久久综合桃花网| 久久久国产精品亚洲一区| 欧美—级a级欧美特级ar全黄| 欧美精品九九久久| 欧美日本在线视频中文字字幕| 久久欧美在线电影| 日韩男女性生活视频| 最新国产精品亚洲| 在线免费观看羞羞视频一区二区| 精品在线观看国产| 亚洲欧美日韩在线高清直播| 日韩网站免费观看高清| 78m国产成人精品视频| 国产美女久久久| 日本精品中文字幕| 国产美女精品视频免费观看| 97视频在线免费观看| 日韩高清电影免费观看完整版| 亚洲精品欧美一区二区三区| 欧美另类极品videosbest最新版本| 久久亚洲一区二区三区四区五区高| 综合国产在线观看| 爽爽爽爽爽爽爽成人免费观看| 久久免费福利视频| 久久精品国产欧美亚洲人人爽| 日韩在线不卡视频| 91精品视频大全| 久久精品99久久香蕉国产色戒| 7m第一福利500精品视频| 精品国产一区二区三区久久久| 亚洲欧美中文字幕| 欧美日韩国产在线看| 丰满岳妇乱一区二区三区| 国产欧美日韩专区发布| 深夜福利91大全| 黑人巨大精品欧美一区免费视频| 青青草一区二区| 在线视频国产日韩| 日韩免费在线播放| 日韩av免费看网站| 色琪琪综合男人的天堂aⅴ视频| 午夜精品久久17c| 久久久久久久激情视频| 高清一区二区三区日本久| 久久久久久18| 久久天天躁狠狠躁夜夜躁2014| 亚洲国产成人精品一区二区| 亚洲乱码av中文一区二区| 欧美有码在线观看| 久久久av电影| 91国产在线精品| 欧美性猛交xxxx黑人猛交| 亚洲精品国产拍免费91在线| 亚洲午夜未满十八勿入免费观看全集| 亚洲福利影片在线| 国产精品久久久久久av福利| 中文字幕亚洲在线| 国产精品爽黄69| 国产日产久久高清欧美一区| 国产精品久久久久久影视| 亚洲欧美在线播放| 97国产精品人人爽人人做|