青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 14,  comments - 57,  trackbacks - 0
   這幾天在玩劍三,突然興趣來了,想要分析劍3的資源打包格式。在資源分析和逆向方面原來偶爾也干過,
不過總體來說還是處于菜鳥階段,這篇文章希望和其他有興趣的兄弟分享下這幾天的經歷,僅僅作為技術研究。


一、安全保護

  一般來說,很少有游戲的資源格式可以直接通過分析資源文件本身得到答案,大部分難免要靜態逆向、動態調試。
無論是靜態逆向還是動態調試,首先需要知道當前exe和dll的保護情況,用peid查看,發現只有gameupdater.exe 用upx加殼了。不太明白金山為什么對客戶端沒有加殼。
其實我并不關心gameupdater.exe 是否加殼,畢竟要動態分析的目標是JX3Client.exe ,要動態調試JX3Client.exe,首先要解決啟動參數問題。

二、啟動參數

  如果直接啟動JX3Client.exe,JX3Client.exe會直接退出,并啟動gameuodater.exe,然后通過gameupdater.exe啟動JX3Client.exe。
這種啟動方式會影響動態調試,所以首先我需要找出JX3Client.exe的啟動參數。打開IDA逆向,轉到啟動處,匯編代碼如下:
start proc near
call    ___security_init_cookie
jmp     ___tmainCRTStartup
start endp
這是一個典型的VC程序入口,在___tmainCRTStartup 里,crt會初始化全局變量、靜態變量,然后進入main,我們需要做的是直接找到main,
跟進去,會發現IDA已經幫我們找到WinMain了,直接跟進去,
關鍵代碼在WinMain的入口處:

從這個代碼片段可以知道,WinMain開始就比較了命令行參數是否是"DOTNOTSTARTGAMEBYJX3CLIENT.EXE ",如果不是,
則轉到啟動更新程序了。這個好辦,我們寫一個run.bat,內容只有一行:
JX3Client.exe DOTNOTSTARTGAMEBYJX3CLIENT.EXE
運行,果然,直接看到加載界面了。

三、PAK文件管理

  在劍3里,PAK目錄下有很多PAK文件,劍3是通過package.ini 來加載和管理pak內部文件的。
這個文件內容如下:
[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文件都列出來了,其實劍3的資源文件打包方式基本上和新劍俠情緣類似(細節還是有比較大的差別)。
打開ollyDbg,帶參數啟動JX3Client.exe,在CreateFile設置斷點,可以發現,package.ini 的讀取和處理是在
Engine_Lua5.dll 的g_LoadPackageFiles 函數,熟悉新劍俠情緣資源管理方式的同學大概會猜到這個函數是做什么的,先看看函數內容吧,這個函數比較長
只能逐步的分析了,首先是打開ini文件

使用g_OpenIniFile打開前面提到的ini文件,如果打開失敗,自然直接返回了。
打開成功后,循環讀取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        ; 這是根據數字生成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內容 readString(section, key)
test    eax, eax
jz      loc_1001127A

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

后面的注釋是我分析的時候加上的,IDA這個功能不錯!
首先new一個0x20字節的空間用來存儲pak對象(我自己命名的類),接著調用構造函數,創建pak對象。
創建對象后,要用這個Pak對象打開對應的pak文件了,這是我們下面的代碼:

首先通過
mov     [edi+edx*4], eax
將對象保存,然后,調用這個類的成員函數打開pak文件,具體代碼在sub_10010ca0。

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


這里做的是驗證文件格式,和一些必要的驗證。

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


posted on 2010-07-15 21:07 feixuwu 閱讀(5272) 評論(10)  編輯 收藏 引用 所屬分類: 逆向工程

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

文章轉載請注明出處

常用鏈接

留言簿(11)

隨筆分類

隨筆檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久综合色8888| 亚洲欧美激情四射在线日 | 欧美日韩三级视频| 亚洲精品九九| 夜夜嗨av一区二区三区四区| 欧美日韩裸体免费视频| 亚洲欧美激情四射在线日| 午夜精品久久久久久久99樱桃| 国产综合色一区二区三区| 欧美大片网址| 欧美性猛交xxxx乱大交退制版| 欧美亚洲免费高清在线观看| 久久九九99| 99精品久久久| 欧美一二三视频| 亚洲精品乱码视频| 亚洲影院一区| 亚洲国产精品成人综合色在线婷婷| 久久精品国产一区二区三| 国产精品国产三级国产aⅴ浪潮| 午夜影视日本亚洲欧洲精品| 亚洲欧美日韩久久精品| 亚洲国产精品99久久久久久久久| 亚洲精品国偷自产在线99热| 欧美日韩在线综合| 美女主播精品视频一二三四| 欧美三级午夜理伦三级中文幕 | 欧美一级久久久| 另类av一区二区| 午夜精品久久久久久久| 久热re这里精品视频在线6| 亚洲专区在线视频| 久久蜜桃精品| 久久久国产一区二区| 欧美日韩亚洲一区二区三区在线观看 | 欧美精品一区二| 久久久久久亚洲精品中文字幕 | 性做久久久久久免费观看欧美 | 国产日韩av一区二区| 亚洲精品1区2区| 精品不卡一区| 先锋亚洲精品| 亚洲欧美日韩网| 欧美日韩一区二区视频在线| 亚洲大胆人体在线| 好吊色欧美一区二区三区四区 | 亚洲国产另类久久精品| 国内激情久久| 欧美在线视频免费观看| 亚洲欧美一区二区三区极速播放 | 欧美母乳在线| 亚洲福利视频二区| 亚洲大片在线| 久久夜色精品| 欧美暴力喷水在线| 亚洲国产一区二区三区在线播| 欧美中文在线视频| 久久影音先锋| 精品二区视频| 久久亚洲欧美| 亚洲福利视频二区| 日韩午夜av| 欧美日韩成人网| 夜夜夜精品看看| 亚洲综合日韩在线| 国产精品视频一二三| 亚洲一区二区三区四区五区午夜 | 亚洲伊人第一页| 日韩午夜剧场| 一区二区三区你懂的| 欧美黑人在线观看| 亚洲精品国产品国语在线app | 欧美视频在线观看免费| 中文网丁香综合网| 久久av最新网址| 狠狠色噜噜狠狠色综合久 | 亚洲网站视频| 久久av一区二区三区| 国内自拍一区| 欧美第一黄色网| 国产精品99久久久久久有的能看 | 亚洲字幕在线观看| 国产三区精品| 美女免费视频一区| 99re6热在线精品视频播放速度| 亚洲免费在线看| 激情成人在线视频| 欧美国产精品久久| 亚洲伊人久久综合| 暖暖成人免费视频| 一区二区三区久久精品| 国产欧美日韩一区| 欧美 亚欧 日韩视频在线| 一本色道综合亚洲| 免费成人美女女| 亚洲一区二区三区涩| 激情六月婷婷久久| 欧美视频一区二区| 久久视频在线看| 亚洲午夜在线视频| 欧美激情精品久久久六区热门 | 麻豆91精品| 亚洲无玛一区| 在线播放日韩| 国产精品日本欧美一区二区三区| 久久久久一区二区| 亚洲一区尤物| 亚洲精品看片| 欧美99在线视频观看| 亚洲欧美日韩系列| 9国产精品视频| 一区二区三区在线免费观看| 欧美亚一区二区| 欧美顶级大胆免费视频| 欧美一级网站| 亚洲自拍偷拍一区| 亚洲美女电影在线| 欧美激情第一页xxx| 久久精品免费播放| 性久久久久久| 亚洲性夜色噜噜噜7777| 亚洲美女在线观看| 亚洲国产日韩欧美| 亚洲第一福利视频| 国产综合色在线| 国产丝袜一区二区| 国产精品视频大全| 国产精品九九久久久久久久| 欧美人妖另类| 欧美欧美全黄| 欧美激情视频一区二区三区免费 | 狠狠干综合网| 日韩视频免费大全中文字幕| 1024亚洲| 亚洲国产精品一区| 在线观看日韩一区| 伊人久久综合| 亚洲国产经典视频| 亚洲精品1234| 亚洲毛片一区二区| 99re热这里只有精品视频| 亚洲精品国产精品乱码不99| 亚洲黄色成人久久久| 亚洲看片一区| 一区二区三区精密机械公司 | 国产精品毛片大码女人| 国产精品户外野外| 国产欧美日韩一区二区三区| 国产欧美一区二区三区另类精品| 国产乱码精品一区二区三区av| 国产精品丝袜91| 国产一二精品视频| 亚洲国产合集| 亚洲视频在线观看视频| 午夜亚洲伦理| 久久久夜色精品亚洲| 欧美黄色一级视频| 日韩视频免费| 性欧美精品高清| 免费亚洲电影| 国产精品美女久久久久久免费| 国产精品日韩在线播放| 国产一区二区中文字幕免费看| 影音先锋另类| 国产精品99久久久久久白浆小说| 亚洲欧美另类久久久精品2019| 性娇小13――14欧美| 欧美va亚洲va国产综合| 亚洲精品一二区| 性欧美长视频| 欧美高清自拍一区| 国产精品一区免费在线观看| 一区国产精品| 午夜精品久久久久久| 欧美暴力喷水在线| 亚洲一级高清| 欧美二区在线看| 国产视频在线观看一区二区三区 | 在线亚洲+欧美+日本专区| 久久国产精品亚洲va麻豆| 亚洲第一福利在线观看| 亚洲中字在线| 欧美日本韩国一区| 国内精品伊人久久久久av一坑| 99av国产精品欲麻豆| 久久午夜精品| 亚洲男人的天堂在线aⅴ视频| 另类专区欧美制服同性| 国产精品一区二区三区成人| 91久久久久| 久久网站热最新地址| 亚洲一区二区三区在线| 欧美高清你懂得| 在线观看亚洲| 久久精品道一区二区三区| 日韩亚洲欧美一区| 免费在线观看一区二区| 黄页网站一区| 久久成人精品| 亚洲欧洲av一区二区|