欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

通過LyScript實(shí)現(xiàn)從文本中讀寫ShellCode

 更新時(shí)間:2022年08月04日 09:23:34   作者:lyshark  
LyScript 插件通過配合內(nèi)存讀寫,可實(shí)現(xiàn)對(duì)特定位置的ShellCode代碼的導(dǎo)出。本文將利用這一特性實(shí)現(xiàn)從文本中讀寫ShellCode,感興趣的可以了解一下

LyScript 插件通過配合內(nèi)存讀寫,可實(shí)現(xiàn)對(duì)特定位置的ShellCode代碼的導(dǎo)出,或者將一段存儲(chǔ)在文本中的ShellCode代碼插入到程序堆中,此功能可用于快速將自己編寫的ShellCode注入到目標(biāo)進(jìn)程中,以用于后續(xù)測試工作。

LyScript項(xiàng)目地址:https://github.com/lyshark/LyScript

將本地ShellCode注入到堆中: 第一種用法是將一個(gè)本地文本中的ShellCode代碼導(dǎo)入到堆中。

首先準(zhǔn)備一個(gè)文本文件,將生成的shellcode放入文件內(nèi)。

然后可以循環(huán)讀取文本,并逐個(gè)將shellcode注入到目標(biāo)堆空間中。

from LyScript32 import MyDebug

# 將shellcode讀入內(nèi)存
def read_shellcode(path):
    shellcode_list = []
    with open(path,"r",encoding="utf-8") as fp:
        for index in fp.readlines():
            shellcode_line = index.replace('"',"").replace(" ","").replace("\n","").replace(";","")
            for code in shellcode_line.split("\\x"):
                if code != "" and code != "\\n":
                    shellcode_list.append("0x" + code)
    return shellcode_list

if __name__ == "__main__":
    dbg = MyDebug()
    dbg.connect()

    # 開辟堆空間
    address = dbg.create_alloc(1024)
    print("開辟堆空間: {}".format(hex(address)))
    if address == False:
        exit()

    # 設(shè)置內(nèi)存可執(zhí)行屬性
    dbg.set_local_protect(address,32,1024)

    # 從文本中讀取shellcode
    shellcode = read_shellcode("d://shellcode.txt")

    # 循環(huán)寫入到內(nèi)存
    for code_byte in range(0,len(shellcode)):
        bytef = int(shellcode[code_byte],16)
        dbg.write_memory_byte(code_byte + address, bytef)

    # 設(shè)置EIP位置
    dbg.set_register("eip",address)
    
    input()
    dbg.delete_alloc(address)

    dbg.close()

執(zhí)行后,堆空間內(nèi)會(huì)自動(dòng)填充。

如果把這個(gè)過程反過來,就是將特定位置的匯編代碼保存到本地。

from LyScript32 import MyDebug

# 將特定內(nèi)存保存到文本中
def write_shellcode(dbg,address,size,path):
    with open(path,"a+",encoding="utf-8") as fp:
        for index in range(0, size - 1):
            # 讀取機(jī)器碼
            read_code = dbg.read_memory_byte(address + index)

            if (index+1) % 16 == 0:
                print("\\x" + str(read_code))
                fp.write("\\x" + str(read_code) + "\n")
            else:
                print("\\x" + str(read_code),end="")
                fp.write("\\x" + str(read_code))

if __name__ == "__main__":
    dbg = MyDebug()
    dbg.connect()

    eip = dbg.get_register("eip")
    write_shellcode(dbg,eip,128,"d://lyshark.txt")
    dbg.close()

寫出后的文件如下:

到此這篇關(guān)于通過LyScript實(shí)現(xiàn)從文本中讀寫ShellCode的文章就介紹到這了,更多相關(guān)LyScript文本讀寫ShellCode內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python字符串和字典相關(guān)操作的實(shí)例詳解

    Python字符串和字典相關(guān)操作的實(shí)例詳解

    這篇文章主要介紹了Python字符串和字典相關(guān)操作的實(shí)例詳解的相關(guān)資料,這里提供實(shí)例幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下
    2017-09-09
  • Python設(shè)計(jì)模式之命令模式簡單示例

    Python設(shè)計(jì)模式之命令模式簡單示例

    這篇文章主要介紹了Python設(shè)計(jì)模式之命令模式,簡單介紹了命令模式的概念、原理,并結(jié)合實(shí)例形式分析了Python命令模式的定義與使用相關(guān)操作技巧,需要的朋友可以參考下
    2018-01-01
  • 用Pygal繪制直方圖代碼示例

    用Pygal繪制直方圖代碼示例

    這篇文章主要介紹了用Pygal繪制直方圖代碼示例,具有一定借鑒價(jià)值,需要的朋友可以了解下。
    2017-12-12
  • Pycharm沒有報(bào)錯(cuò)提示(誤觸ignore)的完美解決方案

    Pycharm沒有報(bào)錯(cuò)提示(誤觸ignore)的完美解決方案

    這篇文章主要介紹了Pycharm沒有報(bào)錯(cuò)提示(誤觸ignore)的解決方案,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-12-12
  • Python qrcode 生成一個(gè)二維碼的實(shí)例詳解

    Python qrcode 生成一個(gè)二維碼的實(shí)例詳解

    在本篇文章里小編給大家整理的是關(guān)于Python qrcode 生成一個(gè)二維碼的實(shí)例內(nèi)容,需要的朋友們可以學(xué)習(xí)參考下。
    2020-02-02
  • 如何使用django的MTV開發(fā)模式返回一個(gè)網(wǎng)頁

    如何使用django的MTV開發(fā)模式返回一個(gè)網(wǎng)頁

    這篇文章主要介紹了如何使用django的MTV開發(fā)模式返回一個(gè)網(wǎng)頁,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • Python的Tkinter點(diǎn)擊按鈕觸發(fā)事件的例子

    Python的Tkinter點(diǎn)擊按鈕觸發(fā)事件的例子

    今天小編就為大家分享一篇Python的Tkinter點(diǎn)擊按鈕觸發(fā)事件的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • 使用Python創(chuàng)建一個(gè)隨機(jī)密碼生成器

    使用Python創(chuàng)建一個(gè)隨機(jī)密碼生成器

    密碼安全是當(dāng)前數(shù)字時(shí)代的一個(gè)重要議題,在保護(hù)個(gè)人信息和賬戶安全方面,安全且可靠的密碼是至關(guān)重要的,本文將帶您逐步了解如何使用Python創(chuàng)建一個(gè)隨機(jī)密碼生成器,以生成高強(qiáng)度、難以猜測的密碼,需要的朋友可以參考下
    2024-01-01
  • 通用的Django注冊(cè)功能模塊實(shí)現(xiàn)方法

    通用的Django注冊(cè)功能模塊實(shí)現(xiàn)方法

    這篇文章主要介紹了通用的Django注冊(cè)功能模塊實(shí)現(xiàn)步驟,幫助大家更好的理解和使用django,感興趣的朋友可以了解下
    2021-02-02
  • Python中的取模運(yùn)算方法

    Python中的取模運(yùn)算方法

    今天小編就為大家分享一篇Python中的取模運(yùn)算方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-11-11

最新評(píng)論