那曲檬骨新材料有限公司

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

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

3天內不再提示

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

Linux閱碼場 ? 來源:寫個解 ? 作者:吳解君 ? 2021-09-24 10:37 ? 次閱讀

1. 背景

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

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

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

2. 演示

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

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

為了便于闡述原理,我編譯源碼帶上調試選項:-g,生成的可執行文件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字節位置找到相應機器碼。

3. 開始破解

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

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

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

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

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

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

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

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

責任編輯:haq

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

    關注

    69

    文章

    5013

    瀏覽量

    88085
  • 指令
    +關注

    關注

    1

    文章

    611

    瀏覽量

    35817

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

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

收藏 人收藏

    評論

    相關推薦

    相器和電荷泵的結構設計及優化

    相器+電荷泵(PFD+CP)是鎖相環內部的重要結構,在通信系統、頻率合成以及時鐘信號生成中有著廣泛的應用。相器用于檢測兩個輸入信號的相位差,電荷泵把相器輸出的相位差轉換成電荷輸送給濾波器,用于給后續的震蕩器提供控制電壓。本
    的頭像 發表于 01-02 09:39 ?1868次閱讀
    <b class='flag-5'>鑒</b>相器和電荷泵的結構設計及優化

    LMX2595相頻率和電荷泵電流關系如何評估,以及對雜散相噪的相關評估?

    請問相頻率和電荷泵電流關系如何評估,以及對雜散相噪的相關評估?
    發表于 11-11 06:58

    什么是相器?

    相器是一種重要的電子元件,廣泛應用于信號處理、通信系統和測量儀器中。它的主要功能是比較兩個信號的相位差,并輸出與相位差相關的信號。本文將詳細介紹相器的基本概念、工作原理、類型、技術參數及其應用領域,幫助您更好地理解這一關鍵組
    的頭像 發表于 10-05 13:38 ?1676次閱讀

    上汽通用汽車NOP智慧領航輔助駕駛系統重磅上線

    7月15日;上汽通用汽車NOP智慧領航輔助駕駛系統重磅上線。能夠實現L2+級高階輔助駕駛能力,目前適用范圍已覆蓋國內城市348個,可用里程超40萬公里。上汽通用汽車成為國內率先推出的高速領航輔助功能
    的頭像 發表于 07-15 17:00 ?1324次閱讀

    RV32I 基本整數指令集(2.0版本)簡介

    、邏輯右移、算術右移,被移位的操作數是寄存器rs1,移位次數是寄存器rs2的低5位。 NOP指令 NOP指令并不改變任何用戶可見的狀態,除
    發表于 06-24 17:27

    數控車床m99指令的用法

    數控車床是一種高度自動化的機床,廣泛應用于機械加工領域。在數控車床的編程中,M代碼(輔助功能代碼)起著非常重要的作用。M99指令是數控車床編程中的一種輔助功能代碼,用于實現程序的循環調
    的頭像 發表于 06-14 15:52 ?5168次閱讀

    何用代碼在運行的時候設置程序防止被讀出?

    何用代碼在運行的時候設置程序防止被讀出
    發表于 06-03 07:24

    科技 Keysight World 2024

    。君科技作為是德科技連續4年首選租賃合作伙伴,也攜多項完整測試應用解決方案參展。作為國內領先的測試儀器綜合服務商,君科技為現場觀眾展示了數字通信接口測試系統、功
    的頭像 發表于 05-30 08:28 ?464次閱讀
    君<b class='flag-5'>鑒</b>科技  Keysight World 2024

    STM32如何用HAL庫進行內核復位?

    STM32如何用HAL庫進行內核復位 普通的系統復位函數如下: / ** 簡短的系統重置 詳細信息發起系統重置請求以重置MCU。 * / __STATIC_INLINE void
    發表于 04-11 06:49

    STM8S的NOP指令一個周期是多少?

    大家好,STM8S的NOP指令一個周期是多少?現在外部晶振16MHZ,CPU不分頻,請問NOP的周期是多少?因為想用NOP做延時,謝謝!
    發表于 04-09 07:54

    蔚來全域領航輔助NOP+已覆蓋全國99%城市,驗證里程超

    據悉,目前蔚來全域領航輔助NOP+已經覆蓋我國內地99%的地級市和縣級市,總計達到了726個城市。相比于2月份,智能駕駛方面新增的匯路成網城市數量為120個,累計道路驗證里程超過100萬公里。
    的頭像 發表于 03-08 13:57 ?691次閱讀

    loop指令的用法及功能

    循環指令是計算機編程中的一種基本控制結構,用于重復執行特定的代碼塊,以實現重復操作、批處理和自動化等功能。循環指令在編程中具有廣泛的應用場景,并且使用循環可以大大提高代碼效率和減少冗余
    的頭像 發表于 02-14 16:12 ?2360次閱讀

    循環指令loop規定循環次數

    循環指令是計算機編程中非常重要的概念,它允許程序重復執行一段代碼塊,使得程序可以更有效地處理大量數據和重復性任務。在本文中,我們將詳盡、詳實、細致地介紹循環指令相關概念、語法和應用場
    的頭像 發表于 02-14 16:10 ?1822次閱讀

    數控編程的g功能代碼是什么

    數控編程中,G代碼(也稱為指令代碼)是一種用于控制數控機床運動、輔助功能和工作過程的指令。在數控編程中,通過一系列的G代碼
    的頭像 發表于 02-14 15:51 ?4368次閱讀

    g代碼和m代碼表示什么功能

    G代碼和M代碼是數控機床程序中常用的兩種指令代碼,用于控制數控機床的工作動作和運動方式。 G代碼是指控制機床工作動作的
    的頭像 發表于 02-14 15:49 ?4659次閱讀
    k7娱乐城备用网址| 百家乐资金注码| 百家乐官网博彩网太阳城娱乐城| 百家乐大娱乐场开户注册| 博彩现金开户| 百家乐官网金海岸软件| 玩百家乐保时捷娱乐城| 威尼斯人娱乐网站安全吗| 百家乐官网视频游戏挖坑| 钱隆百家乐官网的玩法技巧和规则 | 模拟百家乐游戏软件| 大发888娱乐场下载远程| 百家乐官网投注杀手| 优博百家乐现金网平台| 星河娱乐| 新濠百家乐官网的玩法技巧和规则| 威尼斯人娱乐城在线赌博| 百家乐官网视频游戏账号| 澳门百家乐真人版| 万载县| 网上百家乐的技巧| e娱乐城棋牌| 网络百家乐可靠吗| 免费百家乐官网奥秘| 百家乐筹码500| 瑞安市| 百家乐打揽法| 玩百家乐官网新太阳城| 太阳城娱乐正网| 南宁百家乐官网赌| 大发888官网e世博官方网站| 南宁百家乐官网赌| 利来网上娱乐| 七胜百家乐娱乐平台| 真人百家乐官网免费开户送钱| 职业百家乐的玩法技巧和规则| 赌场百家乐官网投注公式| 威尼斯人娱乐网网上百家乐的玩法技巧和规则 | 百家乐筹码桌| 太阳城百家乐官网投注| 百家乐娱乐平台会员注册|