PE文件(十五)綁定導入表

我們在分析Windows自帶的一些程序時,常常發現有的程序,如notepad,他的IAT表在文件加載內存前已經完成綁定,存儲了函數的地址。這樣做可以使得程序是無需修改IAT表而直接啟動,這時程序啟動速度變快。但這種方式只適用于dll按照預先設定ImageBase裝載而不重分配的情況

當dll沒有按照預先設定的ImageBase進行裝載,IAT表在文件加載內存前進行綁定就會出現問題了

為了判斷一個程序的IAT是否在加載內存前就已經進行了綁定,PE的導入表中提供了TimeDateStamp時間戳成員變量:當該值為0時,表示該導入表對應的IAT表在加載內存前尚未綁定。當該值為-1時,表示該導入表對應的IAT表加載內存前已經綁定。而真正綁定的時間存儲在綁定導入表中

綁定導入表

綁定導入表:用于存儲已經綁定(即完成綁定導入)的外部函數的信息。一個綁定導入表對應一個dll,通常存在于Windows操作系統自帶的程序中,但在win10以后操作系統中,其自帶的程序已經很少有綁定導入表了,逐漸被棄用

定位

通過數據目錄的第12個結構我們便可以定位到綁定導入表地址:

201545

當有綁定導入表時,其起始地址是在節表后面,因此在新增節的時候,節表后面的數據不建議更改

結構

綁定導入表的結構如下:

struct _IMAGE_BOUND_IMPORT_DESCRIPTOR{						DWORD TimeDateStamp; 			WORD OffsetModuleName;	WORD NumberOfModuleForwarderRefs;  		
};  

DWORD?TimeDateStamp:時間戳,表示IAT表綁定的真正時間

操作系統通過程序使用到的DLL對應的綁定導入表結構中TimeDateStamp和該DLL的可選PE頭中的TimeDateStamp進行對比判斷dll在綁定IAT表以后是否發生修改:

如果兩個時間戳一樣:DLL的創建時間和把DLL中的函數絕對地址綁定到IAT表的時間是一樣,表明在綁定IAT表以后,DLL沒有更新或者修改。

如果兩個時間戳不一樣:DLL在創建以后被更新或者修改了,此時綁定到IAT表中的函數地址可能出現錯誤。這是由于DLL中的函數地址可能變了,但綁定到IAT中的數據可能是以前的函數地址

WORD OffsetModuleName:該值加上所有綁定導入表中的第一個綁定導入表的RVA表示該綁定導入表對應的DLL的名稱的RVA

WORD NumberOfModuleForwarderRefs:一個dll可能依賴于其他的dll,該值表示該dll依賴的其他的dll的數量。有多少dll,綁定導入表后就緊跟著多少_IMAGE_BOUND_FORWARDER_REF結構

_IMAGE_BOUND_FORWARDER_REF結構如下:

struct _IMAGE_BOUND_FORWARDER_REF {			DWORD TimeDateStamp;  //時間戳		WORD OffsetModuleName;  //對應DLL的名字WORD Reserved;  //保留(未使用)	
};

?TimeDataStamp:和綁定導入表結構中的TimeDateStamp含義和用途是一樣的

OffsetModuleName:和綁定導入表結構中的OffsetModuleName含義和用途是一樣的

Reserved:保留字段(未使用),沒有任何含義

綁定導入表的文件分布如下:

當有sizeof(_IMAGE_BOUND_IMPORT_DESCRIPTOR)個0,表示綁定導入表結束?? ?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/901420.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/901420.shtml
英文地址,請注明出處:http://en.pswp.cn/news/901420.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

計算機網絡分層模型:架構與原理

前言 計算機網絡通過不同的層次結構來實現通信和數據傳輸,這種分層設計不僅使得網絡更加模塊化和靈活,也使得不同類型的通信能夠順利進行。在網絡協議和通信體系中,最廣為人知的分層模型有 OSI模型 和 TCP/IP模型。這兩種模型分別定義了計算…

Ollama模型顯存管理機制解析與Flask部署方案對比

一、Ollama顯存釋放機制 Ollama部署模型后,顯存占用分為兩種情況: 首次調用后短暫閑置(約5分鐘內): ? 釋放KV Cache等中間計算數據(約回收30%-50%顯存)。 ? 模型權重仍保留在顯存中&#xf…

KWDB創作者計劃—KWDB技術重構:重新定義數據與知識的神經符號革命

引言:數據洪流中的范式危機 在AI算力突破千卡集群、大模型參數量級邁向萬億的時代,傳統數據庫系統正面臨前所未有的范式危機。當GPT-4展現出跨領域推理能力,AlphaFold3突破蛋白質預測精度時,數據存儲系統卻仍在沿用基于關系代數的…

Unified Modeling Language,統一建模語言

UML(Unified Modeling Language,統一建模語言)是一種標準化的圖形化建模語言,用于可視化、規范和文檔化軟件系統的設計。UML 提供了一套通用的符號和規則,幫助開發者、架構師和團隊成員更好地理解和溝通軟件系統的結構…

IO模式精講總結

一、IO模型概述 Java中的IO模型主要分為BIO(同步阻塞IO)、NIO(同步非阻塞IO)和AIO(異步非阻塞IO)三種。它們分別適用于不同的業務場景,理解其核心機制對高性能網絡編程至關重要。 二、BIO&…

使用pybind11開發c++擴展模塊輸出到控制臺的中文信息顯示亂碼的問題

使用pybind11開發供Python項目使用的C++擴展模塊時,如果在擴展模塊的C++代碼中向控制臺輸出的信息中包含中文,python程序的控制臺很容易出現亂碼。以如下C++擴展框架代碼為例(這是對上一篇文章簡明使用pybind11開發pythonc+擴展模塊教程-CSDN博客中的C++擴展框架代碼進行少量…

通過jstack分析線程死鎖場景

死鎖的四個必要條件:互斥、持有并等待、不可搶占、循環等待。 死鎖場景是兩個線程各自持有某個鎖,并試圖獲取對方持有的鎖,導致互相等待。 創建死鎖示例代碼 package io.renren.controller;import org.springframework.web.bind.annotation…

PyTorch梯度:深度學習的引擎與實戰解析

一、梯度:深度學習中的指南針 1.1 什么是梯度? 梯度是函數在某一點變化率最大的方向及其大小,就像爬山時最陡峭的上坡方向。在深度學習中,梯度告訴我們如何調整神經網絡參數,使損失函數最小化。 1.2 梯度的重要性 …

【Python爬蟲】詳細入門指南

目錄 一、簡單介紹 二、詳細工作流程以及組成部分 三、 簡單案例實現 一、簡單介紹 在當今數字化信息飛速發展的時代,數據的獲取與分析變得愈發重要,而網絡爬蟲技術作為一種能夠從互聯網海量信息中自動抓取所需數據的有效手段,正逐漸走入…

Golang|Channel 相關用法理解

文章目錄 用 channel 作為并發小容器channel 的遍歷channel 導致的死鎖問題用 channel 傳遞信號用 channel 并行處理文件用channel 限制接口的并發請求量用 channel 限制協程的總數量 用 channel 作為并發小容器 注意這里的 ok 如果為 false,表示此時不僅channel為空…

Windows單機模擬MySQL主從復制

這里寫自定義目錄標題 下載MySQL ZIP壓縮包安裝主庫1、創建配置文件2、安裝服務3、初始化數據庫4、啟動服務5、配置主庫 安裝從庫1、配置ini文件2、安裝服務3、初始化數據庫4、啟動服務5、配置從庫6、驗證從庫狀態 操作主庫驗證 下載MySQL ZIP壓縮包 https://dev.mysql.com/do…

OSPF路由引入

一、基本概念與作用 1.OSPF路由引入指通過自治系統邊界路由器(ASBR)將外部路由(如BGP、RIP、靜態路由或其他OSPF進程的路由)注入當前OSPF域,實現跨協議或跨區域的網絡互通?。 其核心作用包括: ?擴展網…

弱口令爆破

1.簡單介紹 弱口令是指一些簡單易猜的密碼,可通過社工方式和一些爆破工具進行破解,以下介紹一款爆破工具的用法。burpsuite簡稱BP,一款可以利用字典破解賬戶密碼的工具。 2.部署網站 可以使用PHPstudy的Apache服務,也可以使用I…

Vue3+Vite前端項目部署后部分圖片資源無法獲取、動態路徑圖片資源報404錯誤的原因及解決方案

目錄 Vue3vite前端項目部署后部分圖片資源無法獲取、動態路徑圖片資源報404錯誤的原因及解決方案 一、情景介紹 1、問題出現的場景 2、無法加載的圖片寫法 二、反向代理原理簡介 三、造成該現象的原因 四、解決方案 1、放棄動態渲染 2、在頁面掛載的時候引入圖片資源 …

詳解如何從零用 Python復現類似 GPT-4o 的多模態模型

🧠 向所有學習者致敬! “學習不是裝滿一桶水,而是點燃一把火。” —— 葉芝 我的博客主頁: https://lizheng.blog.csdn.net 🌐 歡迎點擊加入AI人工智能社區! 🚀 讓我們一起努力,共創…

榕壹云無人共享系統:基于SpringBoot+MySQL+UniApp的物聯網共享解決方案

無人共享經濟下的技術革新 隨著無人值守經濟模式的快速發展,傳統共享設備面臨管理成本高、效率低下等問題。榕壹云無人共享系統依托SpringBootMySQLUniApp技術棧,結合物聯網與移動互聯網技術,為商家提供低成本、高可用的無人化運營解決方案。…

基于PHP的酒店網上訂房系統(源碼+lw+部署文檔+講解),源碼可白嫖!

摘要 酒店服務是旅游行業的一個重要組成部分,它的作用已經從過去的單一的住宿、結算帳務向全面、高水平的服務型酒店轉變。酒店的服務工作貫穿于整個酒店的市場營銷、預定、入住、退房、結賬等環節,酒店要提高整體工作水平,簡化工作程序&…

【Linux生成SSH秘鑰實現遠程連接】Linux生成SSH秘鑰對與修改服務配置文件實現無密碼遠程連接

文章目錄 前言1. Linux 生成SSH秘鑰對2. 修改SSH服務配置文件3. 客戶端秘鑰文件設置4. 本地SSH私鑰連接測試5. Linux安裝Cpolar工具6. 配置SSHTCP公網地址7. 遠程SSH私鑰連接測試8. 固定SSH公網地址9. 固定SSH地址測試 前言 在數字化江湖中,企業對各種技術的需求就…

# linux 設置寬容模式

linux 設置寬容模式 在Linux系統中,通常沒有直接稱為“寬容模式”的設置選項,但你可以通過幾種方式來模擬或調整系統行為,使其表現得更加“寬容”,特別是在處理錯誤、權限問題或其他潛在問題時。以下是一些常見的方法&#xff1a…

【C++】——lambda表達式

🌟 前言:??C Lambda表達式,當函數開始"叛逆期"?? 你是否有過這樣的崩潰瞬間? 為了寫個??只用到一次??的排序規則,被迫定義了一個類在std::for_each里塞函數指針,代碼瞬間變成"古董級"寫法看著層的循環…