Flare-On4_Challenges 01

来源:http://www.cnblogs.com/hksuki/archive/2017/12/13/8035514.html
-Advertisement-
Play Games

最近在網上找到一個逆向分析挑戰的網站,http://flare-on.com/。在這裡可以下載到該網站出的一系列的逆向分析的題目,我下載了2017年的練習,總共12道題目。最近想把這些題目的結題過程寫下來,當做一些積累吧。 第一道題目是一個網頁題目,開始就給了一個login.html文件 用文本編輯 ...


最近在網上找到一個逆向分析挑戰的網站,http://flare-on.com/。在這裡可以下載到該網站出的一系列的逆向分析的題目,我下載了2017年的練習,總共12道題目。最近想把這些題目的結題過程寫下來,當做一些積累吧。

第一道題目是一個網頁題目,開始就給了一個login.html文件

 

用文本編輯器打開,發現裡面是這樣一段html

<!DOCTYPE Html />
<html>
    <head>
        <title>FLARE On 2017</title>
    </head>
    <body>
        <input type="text" name="flag" id="flag" value="Enter the flag" />
        <input type="button" id="prompt" value="Click to check the flag" />
        <script type="text/javascript">
            document.getElementById("prompt").onclick = function () {
                var flag = document.getElementById("flag").value;
                var rotFlag = flag.replace(/[a-zA-Z]/g, function(c){return String.fromCharCode((c <= "Z" ? 90 : 122) >= (c = c.charCodeAt(0) + 13) ? c : c - 26);});
                if ("[email protected]" == rotFlag) {
                    alert("Correct flag!");
                } else {
                    alert("Incorrect flag, rot again");
                }
            }
        </script>
    </body>
</html>

簡單看下,知道這個網頁上提供了一個文本框,然後對輸入的文本進行加密,並將加密後的文本和"[email protected]"這段字元串進行對比。這裡面的加密演算法則是

var rotFlag = flag.replace(/[a-zA-Z]/g, function(c){return String.fromCharCode((c <= "Z" ? 90 : 122) >= (c = c.charCodeAt(0) + 13) ? c : c - 26);});

如果能夠找到解密演算法,然後利用該演算法對"[email protected]"進行解密操作,就能夠得到輸入的值。現在對這段加密演算法進行分析:

1、該演算法針對輸入的每一個字元進行處理,且處理範圍僅限大小寫字母

2、90和122分別對應'Z'和'z',前面的大小判斷是為了確定該字元是大寫還是小寫

3、後面的判斷則是用'Z'和'z'與該字元加13之後的值進行比較,如大於,變成該字元+13,否則是該字元-13

4、而滿足大於條件的只有字母表中前13個字元滿足

這樣看來,這段加密演算法其實就是前13個字元和後13個字元的替換操作。依據該分析寫解密程式:

char de(char input) {
    if ((input >= 'A' && input < 'A' + 13) || (input >= 'a' && input < 'a' + 13)) {
        return input + 13;
    }
    else if ((input >= 'A' + 13 && input <= 'Z') || (input >= 'a' + 13 && input <= 'z')) {
        return input - 13;
    }
    else
        return input;
}

int main()
{
    char result[] = "[email protected]";
    char origin[38];
    for (auto x : origin) {
        x = 0;
    }
    for (int i = 0; i < strlen(result) + 1; i++) {
        origin[i] = de(result[i]);
    }

    printf("origin input is %s\n", origin);

    return 0;
}

輸出結果為:

測試結果:

 

以上為第一個的分析解決方案,雖然很簡單,但開始的第一步邁出去了,對於練習也好,對於博客也好。雖然寫的很簡單,可能有地方寫的不好,希望看到的大家批評指正!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 問題描述:在vue項目中運行npm run dev啟動伺服器,然而在同一個區域網下的外部設備不能該伺服器 解決方案:在項目的config文件夾下找到index .js中的host把預設的localhost更改為0.0.0.0, 然後外部設備就可以訪問該項目啟動的服務了(註意必須是在統一區域網下) ...
  • 概念: 單例模式:一個類中只有一個實例。 一個類有且僅有一個實例,並且提供了一個全局的訪問點。 使用該模式的起因: 當我們在瀏覽網站時,有些網站會顯示“當前線上人數”。通常,實現這個功能的辦法是將登陸的每一個IP存儲在一個記憶體、文件或者資料庫中,每多一個IP,就實現“+1”。一般就是用一個方法,比如 ...
  • 函數的創建與執行過程 1、當兩個函數名都一樣時,下麵調用函數則會按照最後一個函數體進行調用。2、第一個函數則會變成垃圾記憶體,被python內部的垃圾清理機制給清除掉。3、執行過程如下圖: 函數的參數在傳遞的時候,傳遞的是引用,還是一個值?(答案:引用) 函數在傳參是,引用與傳值的區別: 1、在函數傳 ...
  • 回顧 一、參數的種類: 1、靜態參數: (1)、普通參數:嚴格按照順序,將實際參數複製給形式參數。 (2)、預設參數:一定要放在參數列的最後(即普通參數後面)。 註意: 給預設參數傳參,會被覆蓋掉(例如:XX = OK被BB覆蓋) 預設參數一定要放到,所有參數的末尾否則報錯。 (3)、指定參數:講實 ...
  • 回顧 1、set集合的特點:去重,無序,可嵌套。2、函數:def,參數,名字,函數體,返回值。3、如果是定義函數,則函數體是不會執行的,只有在調用的時候才會執行。 參數的種類 a、普通參數:嚴格按照順序,將實際參數複製給形式參數。 b、預設參數:一定要放在參數列的最後(即普通參數後面)。 註意: 給 ...
  • 編程方法類型 1、面向對象:以類為主要思路,定義的關鍵字class 2、面向過程:以過程為主的思路,定義的關鍵字為def 3、函數式編程:(最早)以函數為主要思路,定義的關鍵字為def 註意:過程和函數的區別就是:過程沒有return 函數式編程的優勢 1、減少代碼的重覆使用: 2、方便代碼的可擴展 ...
  • 操作文件時,一般需要經歷如下步驟: 打開文件操作文件 一、打開文件: 註:python中打開文件有兩種方式,即:open(...) 和 file(...) ,本質上前者在內部會調用後者來進行文件操作,推薦使用 open。 打開文件時,需要指定文件路徑和以何等方式打開文件,打開後,即可獲取該文件句柄, ...
  • 1、引用數據類型 格式:數據類型 變數名 = new 數據類型(); 每個引用類型都有自己的功能,如何使用功能? 格式:變數.方法名,如sc.nextInt(); 接收鍵盤輸入,保證輸入的是整數,否則Exception(異常) Scanner的另外一個功能 next() 接收鍵盤輸入的字元串 ①Sc ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...