哈哈哈哈哈操欧洲电影,久草网在线,亚洲久久熟女熟妇视频,麻豆精品色,久久福利在线视频,日韩中文字幕的,淫乱毛视频一区,亚洲成人一二三,中文人妻日韩精品电影

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何用NOP指令覆蓋相關代碼繞開鑒權

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

掃碼添加小助手

加入工程師交流群

1. 背景

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

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

群里我給他一個破解設計思想:“利用NOP指令覆蓋相關代碼繞開鑒權”。

2. 演示

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

它是怎么實現的呢?先看看源碼,源碼邏輯很簡單,僅僅判斷用戶有沒有money,沒有錢當然沒權限。

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

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(“授權成功

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

”); }}

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

3. 開始破解

接下來這么修改呢?輪到主角nop指令登場。

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

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

有沒有注意到源碼里我寫了若干行指令 ‘asm(“nop”)’,c語言可以嵌入匯編,查看反匯編文件a.dis告訴我nop指令最終編譯得到的機器碼是什么。

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

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

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

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

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯系本站處理。 舉報投訴
  • 軟件
    +關注

    關注

    69

    文章

    5354

    瀏覽量

    91870
  • 指令
    +關注

    關注

    1

    文章

    624

    瀏覽量

    37663

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

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    利用相鑒頻器擴展鎖相環(huán)的捕獲范圍

    本文將了解如何用相/鑒頻器(PFD)替代普通鑒相器,以擴展鎖相環(huán)(PLL)的捕獲范圍。
    的頭像 發(fā)表于 04-22 14:28 ?129次閱讀
    利用<b class='flag-5'>鑒</b>相鑒頻器擴展鎖相環(huán)的捕獲范圍

    2026(春季)亞洲充電展丨紫光同芯安全芯片與功率器件,硬核賦能智慧生活

    安全底座 隨著無線充電技術邁向“安全可信”的新階段,如何構建完善的安全認證體系、實現能耗精益化管理,成為行業(yè)發(fā)展的核心命題。紫光同芯深耕無線充電賽道多年,基于對Qi/Qi2協(xié)議的深度理解與安全芯片技術的深厚積累,打造了覆蓋
    的頭像 發(fā)表于 03-30 13:12 ?205次閱讀

    鑒往知來,篤行致遠|君科技品牌介紹

    23載櫛風沐雨,23載深耕不輟!君科技2002年創(chuàng)立于深圳,始終扎根電子測試賽道,從單一設備租賃到全鏈條科技服務,從區(qū)域布局到全國17城覆蓋,穩(wěn)步成長為硬科技企業(yè)最信賴的測試服務伙伴。今天,一起
    的頭像 發(fā)表于 03-12 09:45 ?165次閱讀
    鑒往知來,篤行致遠|君<b class='flag-5'>鑒</b>科技品牌介紹

    【iotauth 】 IOT 庫的技術實踐

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

    NVMe高速傳輸之擺脫XDMA設計52:主要功能測試結果與分析4(NVMe 指令提交與完成機制測試)

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

    單片機可靠性差的解決辦法

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

    對浮點指令擴展中部分問題的解決與分享

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

    浮點數的指令添加——最終寫回仲裁

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

    浮點數指令添加——最終寫回仲裁

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

    Whetstone代碼涉及的浮點指令匯編分析

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

    RISC-V V擴展的指令代碼

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

    浮點指令擴展中16位指令的處理

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

    全球商用驗證!這款防偽芯片守護數千萬消費電子設備電池安全

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

    NOP912/NOP914運算放大器用于精密電路和高速應用

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

    詳解Linux權限相關指令

    Linux嚴格來說是一個操作系統(tǒng),我們稱之為“核心”(kernel)。而作為用戶的我們并不能直接與核心交流,這時候就有一個中間人的角色出現:將我們的指令翻譯為核心可以看懂的符號,交由核心執(zhí)行,并將執(zhí)行結果翻譯并返回給我們。
    的頭像 發(fā)表于 06-06 11:47 ?1066次閱讀
    詳解Linux權限<b class='flag-5'>相關</b><b class='flag-5'>指令</b>
    桂平市| 吉安市| 武冈市| 吴桥县| 南昌县| 榆中县| 永和县| 区。| 延吉市| 奉新县| 临沂市| 闻喜县| 常州市| 龙川县| 瓦房店市| 丽江市| 安岳县| 文山县| 如皋市| 喀喇| 中卫市| 三门峡市| 深泽县| 罗田县| 河西区| 莒南县| 洛南县| 邳州市| 桃园县| 宜州市| 佳木斯市| 连山| 烟台市| 雅安市| 诸暨市| 溆浦县| 古浪县| 沧州市| 安徽省| 丹寨县| 页游|