91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

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

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

掃碼添加小助手

加入工程師交流群

1. 背景

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

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

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

2. 演示

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

它是怎么實(shí)現(xiàn)的呢?先看看源碼,源碼邏輯很簡單,僅僅判斷用戶有沒有money,沒有錢當(dāng)然沒權(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”); // 無效指令 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. 開始破解

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

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

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

有沒有注意到源碼里我寫了若干行指令 ‘a(chǎn)sm(“nop”)’,c語言可以嵌入?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)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 軟件
    +關(guān)注

    關(guān)注

    69

    文章

    5332

    瀏覽量

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

    關(guān)注

    1

    文章

    623

    瀏覽量

    37548

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

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    【iotauth 】 IOT 權(quán)庫的技術(shù)實(shí)踐

    在智能家居、工業(yè)互聯(lián)網(wǎng)等復(fù)雜場(chǎng)景中,設(shè)備與平臺(tái)之間的信任建立是系統(tǒng)穩(wěn)定運(yùn)行的前提。iotauth權(quán)庫通過模塊化設(shè)計(jì)與多層級(jí)安全策略,實(shí)現(xiàn)了從設(shè)備注冊(cè)、身份驗(yàn)證到會(huì)話管理的全流程覆蓋,助力開發(fā)者高效
    的頭像 發(fā)表于 02-25 17:13 ?45次閱讀
    【iotauth 】 IOT <b class='flag-5'>鑒</b><b class='flag-5'>權(quán)</b>庫的技術(shù)實(shí)踐

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計(jì)52:主要功能測(cè)試結(jié)果與分析4(NVMe 指令提交與完成機(jī)制測(cè)試)

    。 寫完成隊(duì)列的波形如圖 1 所示。 NVMe 設(shè)備通過 axis_cq 接口發(fā)起了一次寫TLP 請(qǐng)求, 寫地址對(duì)應(yīng)了 Admin CQ 地址, 寫數(shù)據(jù)內(nèi)容顯示指令正常完成。 然后 NoP邏輯加速引擎通過
    發(fā)表于 12-04 11:47

    單片機(jī)可靠性差的解決辦法

    使用ERROM空間的填充 在程序存儲(chǔ)器中未使用的EPROM空間,首先填入窄操作指令NOP(無操作指令)。 在NOP指令后,填入一條跳轉(zhuǎn)
    發(fā)表于 11-25 06:10

    對(duì)浮點(diǎn)指令擴(kuò)展中部分問題的解決與分享

    經(jīng)過數(shù)周的前期準(zhǔn)備與研讀代碼,我們組終于正式開始對(duì)浮點(diǎn)指令進(jìn)行擴(kuò)展并不出意外地遇到了一些小問題,本篇文章針對(duì)這些問題作出解決方法的分享。 一. 在e203_exu_decode中,發(fā)現(xiàn)變量
    發(fā)表于 10-24 08:14

    浮點(diǎn)數(shù)的指令添加——最終寫回仲裁

    有優(yōu)先權(quán)進(jìn)行寫回后,代碼中將相應(yīng)的寫回?cái)?shù)據(jù)、寄存器編號(hào)和有效性等信號(hào)發(fā)送到最終寫回到寄存器文件的接口。同時(shí),它還處理錯(cuò)誤和不可寫回的情況。具體來說,如果指令存在錯(cuò)誤或不可寫回,它將被在執(zhí)行單元級(jí)別
    發(fā)表于 10-24 06:29

    浮點(diǎn)數(shù)指令添加——最終寫回仲裁

    有優(yōu)先權(quán)進(jìn)行寫回后,代碼中將相應(yīng)的寫回?cái)?shù)據(jù)、寄存器編號(hào)和有效性等信號(hào)發(fā)送到最終寫回到寄存器文件的接口。同時(shí),它還處理錯(cuò)誤和不可寫回的情況。具體來說,如果指令存在錯(cuò)誤或不可寫回,它將被在執(zhí)行單元級(jí)別
    發(fā)表于 10-24 06:21

    Whetstone代碼涉及的浮點(diǎn)指令匯編分析

    對(duì)benchmark中的whetstone進(jìn)行代碼分析,通過反匯編統(tǒng)計(jì)所出現(xiàn)的浮點(diǎn)指令,共有26種,如下 特點(diǎn)是只涉及單精度的浮點(diǎn)指令,并且存在有浮點(diǎn)Load/Store的壓縮指令
    發(fā)表于 10-22 08:11

    RISC-V V擴(kuò)展的指令代碼

    執(zhí)行指令,可以更加靈活地進(jìn)行程序控制,提高了程序的可編程性和可擴(kuò)展性。 2.指令代碼格式 VADD 指令 vadd.vv v1, v2, v3 這條
    發(fā)表于 10-21 13:11

    浮點(diǎn)指令擴(kuò)展中16位指令的處理

    指令取代對(duì)應(yīng)的寬指令由它們決定。 為了能在一系列的程序上得到良好的代碼壓縮效果, RISC-V 架構(gòu)師精心挑選了 RVC擴(kuò)展中的指令。同時(shí),基于以下的三點(diǎn)觀察,架構(gòu)師們成功地將
    發(fā)表于 10-20 11:02

    全球商用驗(yàn)證!這款防偽權(quán)芯片守護(hù)數(shù)千萬消費(fèi)電子設(shè)備電池安全

    美元,預(yù)計(jì)未來幾年還將繼續(xù)增長,其中一個(gè)重要方向便是消費(fèi)電子領(lǐng)域。 行業(yè)痛點(diǎn)倒逼技術(shù)革新:防偽權(quán)芯片成守護(hù)電池安全剛需 消費(fèi)電子領(lǐng)域的 “假冒亂象” 早已不只是簡單的品牌侵權(quán)問題。例如,未經(jīng)認(rèn)證的第三方手機(jī)電池因質(zhì)量問題可
    的頭像 發(fā)表于 10-17 09:07 ?5366次閱讀
    全球商用驗(yàn)證!這款防偽<b class='flag-5'>鑒</b><b class='flag-5'>權(quán)</b>芯片守護(hù)數(shù)千萬消費(fèi)電子設(shè)備電池安全

    NOP912/NOP914運(yùn)算放大器用于精密電路和高速應(yīng)用

    NOP912/NOP914 運(yùn)算放大器,用于精密電路和高速應(yīng)用 我們都知道運(yùn)算放大器(OP Amps)具有多種功能,包括加法、減法、積分、微分和比較,以及小信號(hào)的信號(hào)和差分放大。這些功能是模擬信號(hào)
    發(fā)表于 09-05 08:15

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

    Linux嚴(yán)格來說是一個(gè)操作系統(tǒng),我們稱之為“核心”(kernel)。而作為用戶的我們并不能直接與核心交流,這時(shí)候就有一個(gè)中間人的角色出現(xiàn):將我們的指令翻譯為核心可以看懂的符號(hào),交由核心執(zhí)行,并將執(zhí)行結(jié)果翻譯并返回給我們。
    的頭像 發(fā)表于 06-06 11:47 ?978次閱讀
    詳解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)用來執(zhí)行計(jì)算任務(wù)的基本操作指令集。這些指令是CPU能夠理解并執(zhí)行的二進(jìn)制代碼,它們?cè)谟?jì)算機(jī)內(nèi)部由硬件控制并按順序執(zhí)行,從而
    的頭像 發(fā)表于 04-18 11:24 ?2651次閱讀

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

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