視頻中明顯把shellcode字符串中的00截斷,與棧上/bin/sh字符串的00截斷混淆了。
提問者:
ciphersaw 2021-12-5
@Roger 視頻中明顯把shellcode字符串中的00截斷,與棧上/bin/sh字符串的00截斷混淆了。
無論壓入/bin/sh還是/bin///sh,00都存在于字符串末尾,而不是字符串中間,因此兩種寫法的字符串均能讀出。視頻中說若壓入/bin/sh字符串,只能讀取到/bin,這種說法是錯誤的。
此外,真正產(chǎn)生00截斷問題的,不是棧上/bin/sh字符串的00截斷,而是shellcode字符串中的00截斷。
視頻中push 0x68對應(yīng)的二進制代碼為6A 68,而push 0x68732F對應(yīng)的二進制代碼為68 2F 73 68 00。
綜上可見,壓入/bin///sh字符串的二進制代碼為6A 68 68 2F 2F 2F 73 68 2F 62 69 6E,而壓入/bin/sh的二進制代碼為68 2F 73 68 00 68 2F 62 69 6E。
真正的截斷問題,出現(xiàn)在壓入/bin/sh的shellcode中出現(xiàn)了00字符,導(dǎo)致后續(xù)的shellcode執(zhí)行失敗。