• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 14,  comments - 57,  trackbacks - 0
               這幾天在玩劍三,突然興趣來(lái)了,想要分析劍3的資源打包格式。在資源分析和逆向方面原來(lái)偶爾也干過(guò),
            不過(guò)總體來(lái)說(shuō)還是處于菜鳥(niǎo)階段,這篇文章希望和其他有興趣的兄弟分享下這幾天的經(jīng)歷,僅僅作為技術(shù)研究。


            一、安全保護(hù)

              一般來(lái)說(shuō),很少有游戲的資源格式可以直接通過(guò)分析資源文件本身得到答案,大部分難免要靜態(tài)逆向、動(dòng)態(tài)調(diào)試。
            無(wú)論是靜態(tài)逆向還是動(dòng)態(tài)調(diào)試,首先需要知道當(dāng)前exe和dll的保護(hù)情況,用peid查看,發(fā)現(xiàn)只有g(shù)ameupdater.exe 用upx加殼了。不太明白金山為什么對(duì)客戶端沒(méi)有加殼。
            其實(shí)我并不關(guān)心gameupdater.exe 是否加殼,畢竟要?jiǎng)討B(tài)分析的目標(biāo)是JX3Client.exe ,要?jiǎng)討B(tài)調(diào)試JX3Client.exe,首先要解決啟動(dòng)參數(shù)問(wèn)題。

            二、啟動(dòng)參數(shù)

              如果直接啟動(dòng)JX3Client.exe,JX3Client.exe會(huì)直接退出,并啟動(dòng)gameuodater.exe,然后通過(guò)gameupdater.exe啟動(dòng)JX3Client.exe。
            這種啟動(dòng)方式會(huì)影響動(dòng)態(tài)調(diào)試,所以首先我需要找出JX3Client.exe的啟動(dòng)參數(shù)。打開(kāi)IDA逆向,轉(zhuǎn)到啟動(dòng)處,匯編代碼如下:
            start proc near
            call    ___security_init_cookie
            jmp     ___tmainCRTStartup
            start endp
            這是一個(gè)典型的VC程序入口,在___tmainCRTStartup 里,crt會(huì)初始化全局變量、靜態(tài)變量,然后進(jìn)入main,我們需要做的是直接找到main,
            跟進(jìn)去,會(huì)發(fā)現(xiàn)IDA已經(jīng)幫我們找到WinMain了,直接跟進(jìn)去,
            關(guān)鍵代碼在WinMain的入口處:

            從這個(gè)代碼片段可以知道,WinMain開(kāi)始就比較了命令行參數(shù)是否是"DOTNOTSTARTGAMEBYJX3CLIENT.EXE ",如果不是,
            則轉(zhuǎn)到啟動(dòng)更新程序了。這個(gè)好辦,我們寫(xiě)一個(gè)run.bat,內(nèi)容只有一行:
            JX3Client.exe DOTNOTSTARTGAMEBYJX3CLIENT.EXE
            運(yùn)行,果然,直接看到加載界面了。

            三、PAK文件管理

              在劍3里,PAK目錄下有很多PAK文件,劍3是通過(guò)package.ini 來(lái)加載和管理pak內(nèi)部文件的。
            這個(gè)文件內(nèi)容如下:
            [SO3Client]
            10=data_5.pak
            1=ui.pak
            0=update_1.pak
            3=maps.pak
            2=settings.pak
            5=scripts.pak
            4=represent.pak
            7=data_2.pak
            6=data_1.pak
            9=data_4.pak
            Path=.\pak
            8=data_3.pak
            基本上PAK目錄下所有的PAK文件都列出來(lái)了,其實(shí)劍3的資源文件打包方式基本上和新劍俠情緣類(lèi)似(細(xì)節(jié)還是有比較大的差別)。
            打開(kāi)ollyDbg,帶參數(shù)啟動(dòng)JX3Client.exe,在CreateFile設(shè)置斷點(diǎn),可以發(fā)現(xiàn),package.ini 的讀取和處理是在
            Engine_Lua5.dll 的g_LoadPackageFiles 函數(shù),熟悉新劍俠情緣資源管理方式的同學(xué)大概會(huì)猜到這個(gè)函數(shù)是做什么的,先看看函數(shù)內(nèi)容吧,這個(gè)函數(shù)比較長(zhǎng)
            只能逐步的分析了,首先是打開(kāi)ini文件

            使用g_OpenIniFile打開(kāi)前面提到的ini文件,如果打開(kāi)失敗,自然直接返回了。
            打開(kāi)成功后,循環(huán)讀取ini配置的文件,讀取的section是SO3Client 讀取的key是0到0x20。

            loc_1001119A:           ; int
            push    0Ah
            lea     ecx, [esp+1A0h+var_178]
            push    ecx             ; char *
            push    ebx             ; int
            call    ds:_itoa        ; 這是根據(jù)數(shù)字生成key的代碼
            mov     edx, [ebp+0]
            mov     edx, [edx+24h]
            add     esp, 0Ch
            push    40h
            lea     eax, [esp+1A0h+var_168]
            push    eax
            mov     eax, [esp+1A4h+var_184]
            push    offset unk_10035B8C
            lea     ecx, [esp+1A8h+var_178]
            push    ecx
            push    eax
            mov     ecx, ebp
            call    edx             ; 讀取INI內(nèi)容 readString(section, key)
            test    eax, eax
            jz      loc_1001127A

            這段是通過(guò)readString("SO3Client", key)來(lái)獲取pak文件名, key就是"0"~"32"的字符串,也就是最多能配置32個(gè)Pak文件。
            獲得了pak文件名后,下面就是打開(kāi)和保存pak文件的索引數(shù)據(jù)了。

            后面的注釋是我分析的時(shí)候加上的,IDA這個(gè)功能不錯(cuò)!
            首先new一個(gè)0x20字節(jié)的空間用來(lái)存儲(chǔ)pak對(duì)象(我自己命名的類(lèi)),接著調(diào)用構(gòu)造函數(shù),創(chuàng)建pak對(duì)象。
            創(chuàng)建對(duì)象后,要用這個(gè)Pak對(duì)象打開(kāi)對(duì)應(yīng)的pak文件了,這是我們下面的代碼:

            首先通過(guò)
            mov     [edi+edx*4], eax
            將對(duì)象保存,然后,調(diào)用這個(gè)類(lèi)的成員函數(shù)打開(kāi)pak文件,具體代碼在sub_10010ca0。

            這段代碼的意思很明白了,打開(kāi)文件,讀取0x20的文件頭,


            這里做的是驗(yàn)證文件格式,和一些必要的驗(yàn)證。

            這段是讀取pak內(nèi)部文件數(shù)目,讀取索引數(shù)據(jù),以備后面查詢使用。
            到此為止,所有pak文件的管理對(duì)象都已經(jīng)加載和設(shè)置完畢了。
            以上內(nèi)容看起來(lái)很順理成章,但是實(shí)際上凝聚了無(wú)數(shù)的失敗和重試。
            后面是pak內(nèi)部文件的查找和讀取了。
            剩下的內(nèi)容明天貼了~~~


            posted on 2010-07-15 21:07 feixuwu 閱讀(5241) 評(píng)論(10)  編輯 收藏 引用 所屬分類(lèi): 逆向工程

            FeedBack:
            # re: 劍3資源格式分析(一)
            2010-07-15 22:50 | johndragon
            你這個(gè),有法律問(wèn)題。。。  回復(fù)  更多評(píng)論
              
            # re: 劍3資源格式分析(一)
            2010-07-16 08:51 | 路青飛
            兄弟,你好強(qiáng),愛(ài)死你了。  回復(fù)  更多評(píng)論
              
            # re: 劍3資源格式分析(一)
            2010-07-16 08:57 | yafare
            @johndragon
            以學(xué)習(xí)為目的的逆向工程是合法的
              回復(fù)  更多評(píng)論
              
            # re: 劍3資源格式分析(一)[未登錄](méi)
            2010-07-16 09:40 | ZUHD
            發(fā)到看雪上去,說(shuō)不定能弄個(gè)精。好久沒(méi)有關(guān)注reverse  回復(fù)  更多評(píng)論
              
            # re: 劍3資源格式分析(一)
            2010-07-16 13:45 | Kevin Lynx
            @johndragon
            這種東西。最好聲明一下,“本文僅用作學(xué)習(xí)” - -  回復(fù)  更多評(píng)論
              
            # re: 劍3資源格式分析(僅用于學(xué)習(xí)和技術(shù)研究)(一)
            2010-07-16 18:03 | billow
            LZ,我可以轉(zhuǎn)貼嗎?想轉(zhuǎn)到看雪去。  回復(fù)  更多評(píng)論
              
            # re: 劍3資源格式分析(僅用于學(xué)習(xí)和技術(shù)研究)(一)
            2010-07-19 14:19 | 單機(jī)游戲下載基地
            這文章不錯(cuò) 我以前玩過(guò)劍三 怎么就沒(méi)想到要研究研究呢呵呵  回復(fù)  更多評(píng)論
              
            # re: 劍3資源格式分析(僅用于學(xué)習(xí)和技術(shù)研究)(一)
            2010-07-19 14:20 | 無(wú)彈窗小說(shuō)網(wǎng)
            我玩到70級(jí)就不想玩了 我玩游戲進(jìn)度太快了 每次都等游戲公司更新等累了。。以前尋仙也是滿級(jí)了 幾個(gè)月沒(méi)新地圖就放棄了  回復(fù)  更多評(píng)論
              
            # re: 劍3資源格式分析(僅用于學(xué)習(xí)和技術(shù)研究)(一)[未登錄](méi)
            2010-10-12 11:14 | king
            # re: 劍3資源格式分析(僅用于學(xué)習(xí)和技術(shù)研究)(一)
            2011-01-13 11:49 | dfdf
            這里的強(qiáng)人真多!  回復(fù)  更多評(píng)論
              
            <2010年7月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            文章轉(zhuǎn)載請(qǐng)注明出處

            常用鏈接

            留言簿(11)

            隨筆分類(lèi)

            隨筆檔案

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久人人妻人人爽人人爽| 婷婷综合久久中文字幕| 久久精品天天中文字幕人妻| 久久亚洲私人国产精品vA | 欧美日韩久久中文字幕| 亚洲AV无码久久| 久久精品国产福利国产琪琪| 久久九九久精品国产免费直播| 久久青青草原国产精品免费 | 久久这里只有精品首页| 国产美女久久久| 午夜人妻久久久久久久久| 久久精品亚洲乱码伦伦中文| 久久久一本精品99久久精品88| AAA级久久久精品无码区| 久久久久久夜精品精品免费啦| 三级三级久久三级久久| 精品久久久久久无码中文野结衣 | 伊人久久大香线蕉精品| 99久久国产热无码精品免费| 99久久国产精品免费一区二区| 国产精品日韩深夜福利久久| 狠色狠色狠狠色综合久久| 色综合久久无码五十路人妻| 亚洲精品综合久久| 精品久久久久久久久免费影院| 久久综合精品国产一区二区三区| 精品人妻伦九区久久AAA片69| 久久综合九色综合久99| 久久精品男人影院| 久久青青草原精品影院| 夜夜亚洲天天久久| 青青草原1769久久免费播放| 国产成人香蕉久久久久| 国产日韩久久免费影院| 久久99精品国产99久久6| 久久久久亚洲精品中文字幕| 亚洲乱码日产精品a级毛片久久| 精品免费久久久久国产一区| 无码乱码观看精品久久| 欧洲成人午夜精品无码区久久|