Imail密碼加密算法及VBS實現(xiàn)
更新時間:2008年04月14日 20:45:08 作者:
用vbs實現(xiàn)的imail的加密算法,安全性大家也許會知道一點了,大家試著破解吧
Imail的所有郵局信息,比如用戶,密碼都實際上都是存儲在計算機注冊表當中的,所以只需要
打開注冊表就可以看到Imail里的所有信息,包括用戶的密碼.
細節(jié):
Imail將企業(yè)郵局信息全部存儲在:
HKEY_LOCAL_MACHINE\SOFTWARE\Ipswitch\IMail\Domains\<DOMAINNAME>\Users\<USERNAME>
這樣一個鍵里,其中DomainName是郵局名,UserName是用戶名,而在<USERNAME>下有一個名叫Password的鍵值則是存儲的用戶密碼.密碼并不是明文存儲的,而是結(jié)這了簡單的加密運行后生成的,他的加密過程如下:
1.讀取用戶名,并將其全部轉(zhuǎn)為小寫
2.將用戶名每個數(shù)字轉(zhuǎn)為對應的ASCII碼
3.計算出用戶名里每個字母和第一個字母的偏移量
4.計算出每個密碼字母對應的ASCII碼
5. 將密碼的每個ASCII碼加上參考值(用戶名首字母的ASCII減去97)再加上用戶名對應的偏移量
6.再對應密碼表就可以得到密碼了.
具體程序如下:
Sub initCode(ByRef Infos) '自動生成密碼表
Count=-97
CodeArray=Array("0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F")
for z=0 to Ubound(CodeArray)
for y=0 to Ubound(CodeArray)
Infos.Add Cstr(Count),CodeArray(z) & CodeArray(y)
Count=Count+1
next
next
End Sub
Function GetImailPassword(User,Pass) 'Imail密碼加密函數(shù)
encryptCode=""
Set objDict=CreateObject("Scripting.Dictionary")
Call initCode(objDict)
User=Lcase(User) '將用戶轉(zhuǎn)為小寫
FirstChar=left(User,1)
FirstCharCode=asc(FirstChar) '得到首字母的ASCII碼
Reference=FirstCharCode-97 '得到參考值
execute "Dim UserCode(" & len(User)-1 & ")" '定義兩個存放用戶與密碼ASCII的數(shù)組
execute "Dim PassCode(" & len(Pass)-1 & ")"
for i=0 to len(User)-1 '取得用戶字母的偏移量
UChar=Asc(mid(User,i+1,1))
UserCode(i)=FirstCharCode-UChar
next
for j=0 to len(Pass)-1 '取得密碼對應的新值
PChar=Asc(mid(Pass,j+1,1))
iPos=j mod len(User)
PassCode(j)=PChar+Reference-UserCode(iPos)
next
for k=0 to Ubound(PassCode) '查詢密碼表,最后得到密碼
encryptCode= encryptCode & objDict.item(Cstr(PassCode(k)))
next
GetImailPassword=encryptCode
end function
iUser="web9898" '測試用的Imail用戶名
iPass="web9898.cn" '測試用的Imail密碼
Wscript.Echo iPass & "加密后的密碼是:" & GetImailPassword(iUser,iPass)
打開注冊表就可以看到Imail里的所有信息,包括用戶的密碼.
細節(jié):
Imail將企業(yè)郵局信息全部存儲在:
HKEY_LOCAL_MACHINE\SOFTWARE\Ipswitch\IMail\Domains\<DOMAINNAME>\Users\<USERNAME>
這樣一個鍵里,其中DomainName是郵局名,UserName是用戶名,而在<USERNAME>下有一個名叫Password的鍵值則是存儲的用戶密碼.密碼并不是明文存儲的,而是結(jié)這了簡單的加密運行后生成的,他的加密過程如下:
1.讀取用戶名,并將其全部轉(zhuǎn)為小寫
2.將用戶名每個數(shù)字轉(zhuǎn)為對應的ASCII碼
3.計算出用戶名里每個字母和第一個字母的偏移量
4.計算出每個密碼字母對應的ASCII碼
5. 將密碼的每個ASCII碼加上參考值(用戶名首字母的ASCII減去97)再加上用戶名對應的偏移量
6.再對應密碼表就可以得到密碼了.
具體程序如下:
Sub initCode(ByRef Infos) '自動生成密碼表
Count=-97
CodeArray=Array("0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F")
for z=0 to Ubound(CodeArray)
for y=0 to Ubound(CodeArray)
Infos.Add Cstr(Count),CodeArray(z) & CodeArray(y)
Count=Count+1
next
next
End Sub
Function GetImailPassword(User,Pass) 'Imail密碼加密函數(shù)
encryptCode=""
Set objDict=CreateObject("Scripting.Dictionary")
Call initCode(objDict)
User=Lcase(User) '將用戶轉(zhuǎn)為小寫
FirstChar=left(User,1)
FirstCharCode=asc(FirstChar) '得到首字母的ASCII碼
Reference=FirstCharCode-97 '得到參考值
execute "Dim UserCode(" & len(User)-1 & ")" '定義兩個存放用戶與密碼ASCII的數(shù)組
execute "Dim PassCode(" & len(Pass)-1 & ")"
for i=0 to len(User)-1 '取得用戶字母的偏移量
UChar=Asc(mid(User,i+1,1))
UserCode(i)=FirstCharCode-UChar
next
for j=0 to len(Pass)-1 '取得密碼對應的新值
PChar=Asc(mid(Pass,j+1,1))
iPos=j mod len(User)
PassCode(j)=PChar+Reference-UserCode(iPos)
next
for k=0 to Ubound(PassCode) '查詢密碼表,最后得到密碼
encryptCode= encryptCode & objDict.item(Cstr(PassCode(k)))
next
GetImailPassword=encryptCode
end function
iUser="web9898" '測試用的Imail用戶名
iPass="web9898.cn" '測試用的Imail密碼
Wscript.Echo iPass & "加密后的密碼是:" & GetImailPassword(iUser,iPass)
相關(guān)文章
用vbscript實現(xiàn)從文本文件中刪除所有重復行的代碼
這篇文章主要為大家介紹了關(guān)于從文本文件中刪除重復名字的類似問題,需要的朋友可以參考一下2007-04-04使用 iisweb.vbs start 啟動網(wǎng)站的方法
這篇文章主要介紹了使用 iisweb.vbs start 啟動網(wǎng)站的方法,需要的朋友可以參考下2014-07-07vbs實現(xiàn)unicode和ascii編碼轉(zhuǎn)換
這篇文章主要介紹了vbs實現(xiàn)unicode和ascii編碼轉(zhuǎn)換,本文同時介紹了OpenTextFile和CreateTextFile的使用,需要的朋友可以參考下2014-11-11vbscript基礎篇 - vbs數(shù)組Array的定義與使用方法
這篇文章主要介紹了vbscript基礎篇 - vbs數(shù)組Array的定義與使用方法,需要的朋友可以參考下2018-05-05