一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何用NOP指令覆蓋相關(guān)代碼繞開(kāi)鑒權(quán)

Linux閱碼場(chǎng) ? 來(lái)源:寫(xiě)個(gè)解 ? 作者:吳解君 ? 2021-09-24 10:37 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1. 背景

群里有個(gè)小伙伴學(xué)習(xí)設(shè)計(jì)加密方法,如同某商用軟件輸入注冊(cè)碼后就能使用擴(kuò)展功能。設(shè)計(jì)時(shí)他很自然的想著所寫(xiě)的加密措施是否足夠健壯安全,是否有什么方法可以繞過(guò)加密檢查,也就是破解。

權(quán)限管理僅在啟動(dòng)后檢查一次注冊(cè)碼是否有效——一個(gè) if 判斷,他也認(rèn)定,若反匯編軟件只要 欺騙過(guò)這條判斷加密措施蕩然無(wú)存。

群里我給他一個(gè)破解設(shè)計(jì)思想:“利用NOP指令覆蓋相關(guān)代碼繞開(kāi)鑒權(quán)”。

2. 演示

下面是我做的一個(gè)例子演示運(yùn)用NOP指令破解:軟件a.out在破解前不是vip,直接修改二進(jìn)制文件后擁有了vip權(quán)限。

它是怎么實(shí)現(xiàn)的呢?先看看源碼,源碼邏輯很簡(jiǎn)單,僅僅判斷用戶有沒(méi)有money,沒(méi)有錢當(dāng)然沒(méi)權(quán)限。

為了便于闡述原理,我編譯源碼帶上調(diào)試選項(xiàng):-g,生成的可執(zhí)行文件a.out反匯編后就能同時(shí)看到源碼和匯編內(nèi)容。

void main(){ int money = 0; int vip = 1;

asm(“nop”); asm(“nop”); asm(“nop”); asm(“nop”); asm(“nop”); asm(“nop”); asm(“nop”); // 無(wú)效指令 if (money == 0) { vip = 0; }

printf(“money %d vip %d

”, money, vip); if (vip == 1) { printf(“授權(quán)成功

”); } else { printf(“未授權(quán)

”); }}

a.dis 是反匯編文件,138行是vip=0的匯編代碼 “movl $0x0,-0x4(%rbp)”, 對(duì)應(yīng)機(jī)器碼為 “c7 45 fc 00 00 00 00” , 左側(cè)窗口內(nèi)容是a.out二進(jìn)制文件,文件第1168字節(jié)位置找到相應(yīng)機(jī)器碼。

3. 開(kāi)始破解

接下來(lái)這么修改呢?輪到主角nop指令登場(chǎng)。

據(jù)我所知,每種處理器都會(huì)有一條瞎忙活的空指令nop(No Operation)。CPU遇到nop指令僅空轉(zhuǎn),浪費(fèi)你的電費(fèi),不干實(shí)際有意義的事情(其實(shí)空轉(zhuǎn)也是為了更有意義的發(fā)揮效能,上班摸魚(yú)是不是能更有活力!), 那么想辦法把“vip=0”這條語(yǔ)句生成7字節(jié)機(jī)器碼 “c7 45 fc 00 00 00 00”,替換成nop指令的機(jī)器碼,是不是就破解了呢?如果nop機(jī)器碼是2字節(jié),我的還需考慮指令完整性對(duì)齊,覆蓋機(jī)器碼長(zhǎng)度必須是nop機(jī)器碼整數(shù)倍。

問(wèn)題來(lái)了:x86的nop指令對(duì)應(yīng)的機(jī)器碼是什么呢?習(xí)慣性百度搜索 “x86 nop 機(jī)器碼”。我這里介紹更簡(jiǎn)潔直接的方法,需要查詢什么反匯編指令,問(wèn)問(wèn)反匯編工具objdump。

有沒(méi)有注意到源碼里我寫(xiě)了若干行指令 ‘a(chǎn)sm(“nop”)’,c語(yǔ)言可以嵌入?yún)R編,查看反匯編文件a.dis告訴我nop指令最終編譯得到的機(jī)器碼是什么。

反匯編后nop的機(jī)器碼是 0x90。謝天謝地,芯片工程師設(shè)計(jì)指令操作碼時(shí)只給它一個(gè)字符。任何正整數(shù)都是1的整數(shù)倍,不用考慮指令完整性對(duì)齊。

順帶留給讀者一個(gè)思考題:對(duì)于x86這種 CISC 復(fù)雜指令集,把nop指令的機(jī)器碼設(shè)計(jì)成只有一個(gè)字節(jié),有什么好處?

替換后的源碼 “vip = 0” 這行如同被注釋掉一樣。

保存修改,再次執(zhí)行,看到了嗎!已經(jīng)得到了VIP權(quán)限。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 軟件
    +關(guān)注

    關(guān)注

    69

    文章

    5147

    瀏覽量

    89166
  • 指令
    +關(guān)注

    關(guān)注

    1

    文章

    616

    瀏覽量

    36404

原文標(biāo)題:黑客最簡(jiǎn)單的軟件破解方法,反匯編nop指令覆蓋

文章出處:【微信號(hào):LinuxDev,微信公眾號(hào):Linux閱碼場(chǎng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    步進(jìn)電機(jī)控制指令詳解

    這些指令主要是針對(duì)用 PLC 直接聯(lián)動(dòng)伺服放大器,目的是可以不借助其他擴(kuò)展設(shè)備(例如1GM 模塊)來(lái)進(jìn)行簡(jiǎn)單的點(diǎn)位控制, 使用這些指令時(shí)最好配合三菱的伺服放大器 (如 MR-J2)。然而,我們也可以用這些指令來(lái)控制步進(jìn)電機(jī)的運(yùn)行
    的頭像 發(fā)表于 06-12 10:33 ?697次閱讀
    步進(jìn)電機(jī)控制<b class='flag-5'>指令</b>詳解

    詳解Linux權(quán)限相關(guān)指令

    Linux嚴(yán)格來(lái)說(shuō)是一個(gè)操作系統(tǒng),我們稱之為“核心”(kernel)。而作為用戶的我們并不能直接與核心交流,這時(shí)候就有一個(gè)中間人的角色出現(xiàn):將我們的指令翻譯為核心可以看懂的符號(hào),交由核心執(zhí)行,并將執(zhí)行結(jié)果翻譯并返回給我們。
    的頭像 發(fā)表于 06-06 11:47 ?420次閱讀
    詳解Linux權(quán)限<b class='flag-5'>相關(guān)</b><b class='flag-5'>指令</b>

    何用 C# 代碼對(duì) FX3/CX3 的 EEPROM 進(jìn)行編程?

    /CyUSB-NET-manual/td-p/105011),我如何用 C# 代碼對(duì) FX3/CX3 的 EEPROM 進(jìn)行編程? 我應(yīng)該使用這個(gè)功能嗎? \"4.9.1
    發(fā)表于 05-26 07:21

    CPU的各種指令和執(zhí)行流程

    在集成電路設(shè)計(jì)中,CPU的指令是指計(jì)算機(jī)中央處理單元(CPU)用來(lái)執(zhí)行計(jì)算任務(wù)的基本操作指令集。這些指令是CPU能夠理解并執(zhí)行的二進(jìn)制代碼,它們?cè)谟?jì)算機(jī)內(nèi)部由硬件控制并按順序執(zhí)行,從而
    的頭像 發(fā)表于 04-18 11:24 ?798次閱讀

    STM32CubeMX生成代碼就會(huì)覆蓋CMakeLists.txt文件,怎么解決?

    請(qǐng)教一下用STM32CubeMX生成代碼后,我自己加了一個(gè)頭文件和源文件,這些自己加的文件不是要配置到CMakeLists.txt編譯么,但下載在用STM32CubeMX生成成代碼,就會(huì)覆蓋CMakeLists.txt文件,這種
    發(fā)表于 03-12 08:03

    請(qǐng)問(wèn)DLPC350 USB指令對(duì)應(yīng)的I2C指令是什么?

    你好,我在對(duì)DLPC350進(jìn)行編程時(shí),查看你們給出的源代碼時(shí),發(fā)現(xiàn)你們?cè)?b class='flag-5'>代碼中給出的USB指令,有幾條我無(wú)法在文檔中找到對(duì)應(yīng)的I2C指令,可以麻煩你們直接告訴我一下嗎?謝謝 USB:
    發(fā)表于 02-20 07:04

    AN-737: 如何用ADIsimADC完成ADC建模

    電子發(fā)燒友網(wǎng)站提供《AN-737: 如何用ADIsimADC完成ADC建模.pdf》資料免費(fèi)下載
    發(fā)表于 01-13 14:54 ?0次下載
    AN-737: 如<b class='flag-5'>何用</b>ADIsimADC完成ADC建模

    相器和電荷泵的結(jié)構(gòu)設(shè)計(jì)及優(yōu)化

    相器+電荷泵(PFD+CP)是鎖相環(huán)內(nèi)部的重要結(jié)構(gòu),在通信系統(tǒng)、頻率合成以及時(shí)鐘信號(hào)生成中有著廣泛的應(yīng)用。相器用于檢測(cè)兩個(gè)輸入信號(hào)的相位差,電荷泵把相器輸出的相位差轉(zhuǎn)換成電荷輸送給濾波器,用于給后續(xù)的震蕩器提供控制電壓。本
    的頭像 發(fā)表于 01-02 09:39 ?2825次閱讀
    <b class='flag-5'>鑒</b>相器和電荷泵的結(jié)構(gòu)設(shè)計(jì)及優(yōu)化

    測(cè)試LMX2582EVM板波形發(fā)現(xiàn)不同的相頻率導(dǎo)致輸出的頻率誤差不同,為什么?

    在對(duì)LMX2582的EVM板進(jìn)行測(cè)試時(shí),輸出1GHz信號(hào),設(shè)置相頻率為100MHz時(shí)輸出接近1GHz的信號(hào),但是設(shè)置相頻率為1MHz時(shí),輸出879MHz的信號(hào),誤差較大,請(qǐng)問(wèn)這是為什么呢?
    發(fā)表于 11-12 08:25

    LMX2595相頻率和電荷泵電流關(guān)系如何評(píng)估,以及對(duì)雜散相噪的相關(guān)評(píng)估?

    請(qǐng)問(wèn)相頻率和電荷泵電流關(guān)系如何評(píng)估,以及對(duì)雜散相噪的相關(guān)評(píng)估?
    發(fā)表于 11-11 06:58

    plc基本指令的應(yīng)用有哪些

    PLC(可編程邏輯控制器)的基本指令是PLC編程語(yǔ)言的基本元素,用于描述PLC如何根據(jù)輸入信號(hào)的狀態(tài)控制輸出信號(hào)的變化,從而實(shí)現(xiàn)對(duì)機(jī)械設(shè)備的控制。PLC的基本指令涵蓋了邏輯運(yùn)算、定時(shí)控制、計(jì)數(shù)
    的頭像 發(fā)表于 10-21 17:16 ?2745次閱讀

    處理器指令的獲取過(guò)程

    微處理器指令的獲取是計(jì)算機(jī)執(zhí)行程序過(guò)程中的關(guān)鍵環(huán)節(jié),它決定了微處理器如何對(duì)數(shù)據(jù)和指令進(jìn)行處理。以下將詳細(xì)闡述微處理器指令的獲取過(guò)程,包括指令的來(lái)源、存儲(chǔ)位置、讀取方式以及
    的頭像 發(fā)表于 10-05 15:16 ?974次閱讀

    什么是相器?

    相器是一種重要的電子元件,廣泛應(yīng)用于信號(hào)處理、通信系統(tǒng)和測(cè)量?jī)x器中。它的主要功能是比較兩個(gè)信號(hào)的相位差,并輸出與相位差相關(guān)的信號(hào)。本文將詳細(xì)介紹相器的基本概念、工作原理、類型、技術(shù)參數(shù)及其應(yīng)用領(lǐng)域,幫助您更好地理解這一關(guān)鍵組
    的頭像 發(fā)表于 10-05 13:38 ?2706次閱讀

    RV64之64位地址指令

    了 PC 相關(guān)數(shù)據(jù)尋址,以更好地支持與位置無(wú)關(guān)的代碼。 ?添加了 PC 相關(guān)數(shù)據(jù)尋址,以更好地支持與位置無(wú)關(guān)的代碼。這些改進(jìn)部分緩和了 x86-32
    發(fā)表于 09-04 15:15

    上汽通用汽車NOP智慧領(lǐng)航輔助駕駛系統(tǒng)重磅上線

    7月15日;上汽通用汽車NOP智慧領(lǐng)航輔助駕駛系統(tǒng)重磅上線。能夠?qū)崿F(xiàn)L2+級(jí)高階輔助駕駛能力,目前適用范圍已覆蓋國(guó)內(nèi)城市348個(gè),可用里程超40萬(wàn)公里。上汽通用汽車成為國(guó)內(nèi)率先推出的高速領(lǐng)航輔助功能
    的頭像 發(fā)表于 07-15 17:00 ?1640次閱讀