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

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


一、安全保護

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

二、啟動參數(shù)

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

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

三、PAK文件管理

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

使用g_OpenIniFile打開前面提到的ini文件,如果打開失敗,自然直接返回了。
打開成功后,循環(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

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

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

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

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


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

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


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

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

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

常用鏈接

留言簿(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>
            1024亚洲| 欧美日韩国产一级| 国产农村妇女毛片精品久久麻豆| 亚洲色图制服丝袜| 亚洲视频在线一区| 国产一区二区福利| 美女在线一区二区| 欧美激情精品久久久久久| 一区二区三区不卡视频在线观看| 99精品福利视频| 国产精品久久看| 久久综合久久综合这里只有精品 | 亚洲免费视频成人| 国产日产精品一区二区三区四区的观看方式| 小嫩嫩精品导航| 久久噜噜噜精品国产亚洲综合 | 国产精品乱子乱xxxx| 久久久久久一区| 欧美成人免费在线视频| 亚洲午夜av在线| 久久九九精品99国产精品| 亚洲精品在线三区| 亚洲免费在线播放| 亚洲裸体俱乐部裸体舞表演av| 亚洲国产美女| 国产精品v日韩精品v欧美精品网站| 久久精品91久久香蕉加勒比| 模特精品在线| 久久嫩草精品久久久精品| 欧美日韩国产在线一区| 久久久精品国产免费观看同学| 久久亚洲二区| 欧美综合国产精品久久丁香| 久久综合伊人| 欧美在线免费观看| 欧美精品一区二| 久久久九九九九| 国产精品va在线播放我和闺蜜| 免费观看日韩av| 国产农村妇女精品| 夜夜嗨一区二区三区| 91久久综合| 久久九九热re6这里有精品| 午夜精品理论片| 欧美日韩视频在线一区二区| 欧美成人午夜激情视频| 国产婷婷色一区二区三区在线| 亚洲区一区二| 日韩午夜三级在线| 美女网站久久| 欧美a级大片| 黄色成人av在线| 亚洲国产精品精华液2区45 | 极品少妇一区二区三区| 亚洲私人黄色宅男| 亚洲乱码国产乱码精品精可以看| 久久久99精品免费观看不卡| 欧美伊人久久大香线蕉综合69| 欧美特黄一级| 一本综合久久| 亚洲在线第一页| 欧美日韩精品在线播放| 亚洲精品视频一区| 亚洲理论电影网| 欧美另类高清视频在线| 亚洲精品综合精品自拍| 99精品欧美一区二区三区| 欧美成人视屏| 亚洲精品日产精品乱码不卡| 99人久久精品视频最新地址| 欧美高清你懂得| 91久久精品网| 在线综合视频| 国产精品免费电影| 欧美一区在线直播| 久久亚洲不卡| 亚洲电影专区| 欧美福利一区二区| 在线一区二区日韩| 久久精品国产清高在天天线| 狠狠爱综合网| 免费在线观看成人av| 日韩一区二区福利| 香港成人在线视频| 国产综合网站| 欧美国产日韩免费| 亚洲午夜久久久久久尤物| 欧美在线免费观看| 亚洲国产日韩欧美| 国产精品av一区二区| 欧美在线观看你懂的| 欧美电影免费观看| 亚洲在线视频观看| 韩国欧美一区| 欧美日韩国产高清| 欧美一区二区三区免费大片| 亚洲国产精品第一区二区| 亚洲午夜视频在线| 国语对白精品一区二区| 欧美精品日韩精品| 欧美在线黄色| 日韩图片一区| 麻豆精品精品国产自在97香蕉| 亚洲毛片在线免费观看| 国产三级欧美三级| 欧美成人在线网站| 午夜在线视频观看日韩17c| 欧美激情精品久久久久久免费印度 | 欧美日韩一区在线视频| 久久精品亚洲精品国产欧美kt∨| 亚洲免费观看视频| 毛片av中文字幕一区二区| 亚洲一区二区伦理| 亚洲娇小video精品| 国产欧美日本一区视频| 欧美精品一卡二卡| 麻豆精品精华液| 欧美在线欧美在线| 亚洲免费一在线| 亚洲视频每日更新| 国产自产精品| 激情综合五月天| 免费看黄裸体一级大秀欧美| 午夜精品久久久久久久久久久久久| 欧美成人有码| 久久一二三国产| 欧美专区在线| 亚洲午夜精品17c| 亚洲免费观看高清在线观看 | 亚洲大胆人体视频| 国产区在线观看成人精品| 欧美日韩国产二区| 欧美激情一区二区三区全黄| 美女视频黄a大片欧美| 久久精品成人欧美大片古装| 亚洲影院免费观看| 亚洲视频精品在线| 一区二区三区视频观看| 99在线精品观看| 亚洲乱码日产精品bd| 亚洲三级影院| 亚洲精品一品区二品区三品区| 亚洲国产精品尤物yw在线观看| 欧美插天视频在线播放| 久久综合国产精品台湾中文娱乐网| 欧美一区二区三区视频在线观看| 亚洲欧美日韩国产中文 | 一区在线影院| 影音先锋欧美精品| 亚洲激情视频| 亚洲日韩欧美视频| 亚洲伦理在线| 亚洲一区二区少妇| 亚洲欧美激情在线视频| 欧美一区观看| 久久亚洲国产精品一区二区| 免费在线看成人av| 欧美国产日韩视频| 亚洲免费成人| 午夜视频在线观看一区| 久久久999国产| 欧美大片va欧美在线播放| 欧美日韩一区二区三区在线观看免| 欧美日韩亚洲国产精品| 国产视频久久网| 亚洲第一精品夜夜躁人人爽| 亚洲精品影院在线观看| 亚洲女女做受ⅹxx高潮| 久久人体大胆视频| 亚洲电影第1页| 亚洲性xxxx| 久久亚洲春色中文字幕| 欧美日一区二区三区在线观看国产免| 国产精品久久久| 在线播放日韩专区| 亚洲一区二区三区中文字幕| 久久一日本道色综合久久| 亚洲精品一区二区三区四区高清| 亚洲一区国产精品| 麻豆av福利av久久av| 国产精品乱码久久久久久| 亚洲大片在线观看| 亚洲欧美成人一区二区在线电影| 久久九九精品| 在线中文字幕日韩| 久久亚洲影院| 国产精品一区二区久久精品| 亚洲激情精品| 久久久天天操| 亚洲视频网在线直播| 欧美成人精品在线视频| 国产伦理一区| 亚洲色图在线视频| 亚洲电影有码| 久久大逼视频| 国产日韩1区| 夜夜嗨av一区二区三区网站四季av| 久久精品国产欧美激情| 亚洲图中文字幕| 欧美日韩a区|