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