搜尋


返回清單
切換到指定樓層
通知這文章過時或找檔案 發表主題

[轉帖] 看不懂什麼是代碼? 數據?

  [複製連結]
1
dox79345 ( Lv.30 大天使 ) 發表於 2011-2-8 22:51:14 | 只看該作者 回覆獎勵 |降序瀏覽 |閱讀模式
[ENABLE]        // 程式開始, ke看到這就會開始complier, 要說明可以在這之上寫入, 不會被complier
registersymbol(tswhaerKiKiVac)        // 向ke註冊一個符號 tswhaerKiKiVac
registersymbol(tswhaerItemVac)  // 向ke登記一個符號 tswhaerItemVac
alloc(tswhaerKiKiVac, 1024)        // 為剛剛註冊的符號配置一段1024-bytes 記憶體區段,即這個label以下                                
                                              // 的code 會被放在這一個區塊中
alloc(tswhaerItemVac, 1024)        // 為剛剛註冊的符號配置一段1024-bytes 記憶體區段
tswhaerKiKiVac:                        // 這個label已註冊, 若未註冊會無法complier喔, 這是全圖打怪
mov edx,[7cd55c]                // 抓取address 0x7cd55c的內含值
lea edx,[edx+xxx]                // 將剛剛的內含值加上offset 0x354後的實際位址放入register edx中
mov ecx,[edx]                        // 將剛剛所得到的位址的內容值讀出入暫存器ecx, 即改變 x 軸的位置,
                                // 若是標賊或弓手可以保持原來的x軸石(mov ecx,[ebx+00000390]),
                                // 才不會用拳頭打怪.
mov edx,[7cd55c]                // 讀取位址0x7cd55c的內容值且放入edx中
lea edx,[edx+xxx]                 // 將剛的內容值edx 加上offset 0x358後的值放入edx中
lea eax,[edx]                        // 將剛得到的edx放入到eax中
mov eax,[eax]                        // 將eax的內容值當成address, 即這位址的內容值讀出放到eax,即y軸
jmp xxxxxx                        // 跳到攔截位址的下面第三行指令集的位置,
                                // 註: 可以全圖打到怪主要是將x,y軸改變而已.讓怪好像在我們身邊.
   
tswhaerItemVac:                 // 這個label已註冊, 且被配置一段記憶體, 這是吸物數據.
pushad                                // 將所有暫存器(依序為eax, ecx, edx, ebx, esp, ebp, esi, edi)
                                // 放入堆疊區段, 因我們會改變程式中的暫存器
                                // 若不先保留會造成楓谷當掉.
mov ecx, [ebp+x]                // 研判是讀取vc在做call時的動作所傳入的參數值, 然後放到ecx中
mov ebx, [ebp-xx]                // 讀出stack 區段中的某個數值.
mov [ecx], ebx                        // 將讀到的值放入ecx內容的位址中
mov [ecx+4], eax                // 將eax的值放入ecx+4的位址中
mov ecx, eax                        // 將eax的值copy一份到ecx中
mov eax, ebx                        // 將ebx的值搬到eax中
lea edx, [eax-xx]                // 將eax的內容減0x19 之後放到edx中
mov [ebp-34], edx                // 將edx傳回參數去
lea edx, [ecx-xx]                // 將ecx的內容值減去0x32, 所得的值放到edx中
add eax, 19                        // 將eax加0x19
add ecx, A                        // 將ecx加0xa
mov [ebp-30], edx                // 更新參數值,vc在call時會將參數放入堆疊中, 而ebp是堆疊的
                                // 基底指標, 所以將edx的值傳回參數位址中
mov [ebp-xx], eax                // 更新參數值
mov [ebp-xx], ecx                // 更新參數值
popad                                // restore 剛被放入堆疊中的暫存器
push eax                        // 要將eax 放入堆疊中, 不然會造成原本的code出現堆疊不同的情形
jmp xxxxxx                        // jump 到吸物代碼的下一個位址
[disable]                        // 當你打勾的部份取消時, ke會將下面的label及記憶體刪除
unregistersymbol(tswhaerKiKiVac)// 註消tswhaerKiKiVac的label
unregistersymbol(tswhaerItemVac)// 註消tswhaerItemVac的label以留給其他要用的人
dealloc(tswhaerKiKiVac)                // 收回記憶體空間
dealloc(tswhaerItemVac)                // 收回記憶體空間


所有站內附件皆會附上安全掃描報告
請會員查看純淨度百分比後判斷使用



相關檔案須知:
取得檔案前,請先詳細閱讀文章內容
避免不必要錯誤與誤會發生。
也可多參考文章討論樓層內容
了解附件檔案相關討論資訊。









大家正在看啥


收藏收藏 分享文章到FB上分享
複製專屬你的推廣連結:發至FB與各論壇宣傳:累積點數換GP商品 & 藍鑽
每五點閱率就可以兌換藍鑽積分或遊戲點卡 夢遊推廣文章換GP商品
2
 樓主| dox79345 ( Lv.30 大天使 ) 發表於 2011-2-8 23:02:00 | 只看該作者
它們在存貯器和寄存器、寄存器和輸入輸出端口之間傳送數據.
1. 通用數據傳送指令.
MOV 傳送字或字節.
MOVSX 先符號擴展,再傳送.
MOVZX 先零擴展,再傳送.
PUSH 把字壓入堆棧.
POP 把字彈出堆棧.
PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次壓入堆棧.
POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次彈出堆棧.
PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次壓入堆棧.
POPAD 把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次彈出堆棧.
BSWAP 交換32位寄存器裡字節的順序
XCHG 交換字或字節.( 至少有一個操作數為寄存器,段寄存器不可作為操作數)
CMPXCHG 比較並交換操作數.( 第二個操作數必須為累加器AL/AX/EAX )
XADD 先交換再累加.( 結果在第一個操作數裡 )
XLAT 字節查表轉換.
── BX 指向一張 256 字節的表的起點, AL 為表的索引值 (0-255,即
0-FFH); 返回 AL 為查表結果. ( [BX+AL]->AL )
2. 輸入輸出端口傳送指令.
IN I/O端口輸入. ( 語法: IN 累加器, {端口號│DX} )
OUT I/O端口輸出. ( 語法: OUT {端口號│DX},累加器 )
輸入輸出端口由立即方式指定時, 其范圍是 0-255; 由寄存器 DX 指定時,
其范圍是 0-65535.
3. 目的地址傳送指令.
LEA 裝入有效地址.
例: LEA DX,string ;把偏移地址存到DX.
LDS 傳送目標指針,把指針內容裝入DS.
例: LDS SI,string ;把段地址:偏移地址存到DS:SI.
LES 傳送目標指針,把指針內容裝入ES.
例: LES DI,string ;把段地址:偏移地址存到ES:DI.
LFS 傳送目標指針,把指針內容裝入FS.
例: LFS DI,string ;把段地址:偏移地址存到FS:DI.
LGS 傳送目標指針,把指針內容裝入GS.
例: LGS DI,string ;把段地址:偏移地址存到GS:DI.
LSS 傳送目標指針,把指針內容裝入SS.
例: LSS DI,string ;把段地址:偏移地址存到SS:DI.
4. 標志傳送指令.
LAHF 標志寄存器傳送,把標志裝入AH.
SAHF 標志寄存器傳送,把AH內容裝入標志寄存器.
PUSHF 標志入棧.
POPF 標志出棧.
PUSHD 32位標志入棧.
POPD 32位標志出棧.

二、算術運算指令
───────────────────────────────────────
  ADD 加法.
ADC 帶進位加法.
INC 加 1.
AAA 加法的ASCII碼調整.
DAA 加法的十進制調整.
SUB 減法.
SBB 帶借位減法.
DEC 減 1.
NEC 求反(以 0 減之).
CMP 比較.(兩操作數作減法,僅修改標志位,不回送結果).
AAS 減法的ASCII碼調整.
DAS 減法的十進制調整.
MUL 無符號乘法.
IMUL 整數乘法.
以上兩條,結果回送AH和AL(字節運算),或DX和AX(字運算),
AAM 乘法的ASCII碼調整.
DIV 無符號除法.
IDIV 整數除法.
以上兩條,結果回送:
商回送AL,餘數回送AH, (字節運算);
或 商回送AX,餘數回送DX, (字運算).
AAD 除法的ASCII碼調整.
CBW 字節轉換為字. (把AL中字節的符號擴展到AH中去)
CWD 字轉換為雙字. (把AX中的字的符號擴展到DX中去)
CWDE 字轉換為雙字. (把AX中的字符號擴展到EAX中去)
CDQ 雙字擴展. (把EAX中的字的符號擴展到EDX中去)

三、邏輯運算指令
───────────────────────────────────────
  AND 與運算.
OR 或運算.
XOR 異或運算.
NOT 取反.
TEST 測試.(兩操作數作與運算,僅修改標志位,不回送結果).
SHL 邏輯左移.
SAL 算術左移.(=SHL)
SHR 邏輯右移.
SAR 算術右移.(=SHR)
ROL 循環左移.
ROR 循環右移.
RCL 通過進位的循環左移.
RCR 通過進位的循環右移.
以上八種移位指令,其移位次數可達255次.
移位一次時, 可直接用操作碼. 如 SHL AX,1.
移位>1次時, 則由寄存器CL給出移位次數.
如 MOV CL,04
SHL AX,CL

四、串指令
───────────────────────────────────────
 DS:SI 源串段寄存器 :源串變址.
ES:DI 目標串段寄存器:目標串變址.
CX 重復次數計數器.
AL/AX 掃描值.
D標志 0表示重復操作中SI和DI應自動增量; 1表示應自動減量.
Z標志 用來控制掃描或比較操作的結束.
MOVS 串傳送.
( MOVSB 傳送字符. MOVSW 傳送字. MOVSD 傳送雙字. )
CMPS 串比較.
( CMPSB 比較字符. CMPSW 比較字. )
SCAS 串掃描.
把AL或AX的內容與目標串作比較,比較結果反映在標志位.
LODS 裝入串.
把源串中的元素(字或字節)逐一裝入AL或AX中.
( LODSB 傳送字符. LODSW 傳送字. LODSD 傳送雙字. )
STOS 保存串.
是LODS的逆過程.
REP 當CX/ECX<>0時重復.
REPE/REPZ 當ZF=1或比較結果相等,且CX/ECX<>0時重復.
REPNE/REPNZ 當ZF=0或比較結果不相等,且CX/ECX<>0時重復.
REPC 當CF=1且CX/ECX<>0時重復.
REPNC 當CF=0且CX/ECX<>0時重復.

五、程序轉移指令
───────────────────────────────────────
 1>無條件轉移指令 (長轉移)
JMP 無條件轉移指令
CALL 過程調用
RET/RETF過程返回.
2>條件轉移指令 (短轉移,-128到+127的距離內)
( 當且僅當(SF XOR OF)=1時,OP1<OP2 )
JA/JNBE 不小於或不等於時轉移.
JAE/JNB 大於或等於轉移.
JB/JNAE 小於轉移.
JBE/JNA 小於或等於轉移.
以上四條,測試無符號整數運算的結果(標志C和Z).
JG/JNLE 大於轉移.
JGE/JNL 大於或等於轉移.
JL/JNGE 小於轉移.
JLE/JNG 小於或等於轉移.
以上四條,測試帶符號整數運算的結果(標志S,O和Z).
JE/JZ 等於轉移.
JNE/JNZ 不等於時轉移.
JC 有進位時轉移.
JNC 無進位時轉移.
JNO 不溢出時轉移.
JNP/JPO 奇偶性為奇數時轉移.
JNS 符號位為 "0" 時轉移.
JO 溢出轉移.
JP/JPE 奇偶性為偶數時轉移.
JS 符號位為 "1" 時轉移.
3>循環控制指令(短轉移)
LOOP CX不為零時循環.
LOOPE/LOOPZ CX不為零且標志Z=1時循環.
LOOPNE/LOOPNZ CX不為零且標志Z=0時循環.
JCXZ CX為零時轉移.
JECXZ ECX為零時轉移.
4>中斷指令
INT 中斷指令
INTO 溢出中斷
IRET 中斷返回
5>處理器控制指令
HLT 處理器暫停, 直到出現中斷或復位信號纔繼續.
WAIT 當芯片引線TEST為高電平時使CPU進入等待狀態.
ESC 轉換到外處理器.
LOCK 封鎖總線.
NOP 空操作.
STC 置進位標志位.
CLC 清進位標志位.
CMC 進位標志取反.
STD 置方向標志位.
CLD 清方向標志位.
STI 置中斷允許位.
CLI 清中斷允許位.

六、偽指令
───────────────────────────────────────
  DW 定義字(2字節).
PROC 定義過程.
ENDP 過程結束.
SEGMENT 定義段.
ASSUME 建立段寄存器尋址.
ENDS 段結束.
END 程序結束.
回覆 使用道具 檢舉
3
qwer4987 ( Lv.10 見習生 ) 發表於 2011-2-10 13:40:38 | 只看該作者
卸卸分享唷 回++

回覆 使用道具 檢舉
4
love0989250156 ( Lv.20 天使 ) 發表於 2011-2-10 21:24:05 | 只看該作者
大大真厲害阿~~~~~
回覆 使用道具 檢舉
5
a9303201 ( Lv.20 天使 ) 發表於 2011-2-10 22:52:59 | 只看該作者
匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴 匈奴
回覆 使用道具 檢舉
6
tonyjne123 ( Lv.00 違規者 ) 發表於 2011-2-12 19:06:21 | 只看該作者
= =玵部有看沒有懂  嗚嗚  我想要學如何改掛啦
回覆 使用道具 檢舉
7
瞳玉 ( Lv.10 見習生 ) 發表於 2011-4-12 20:07:27 | 只看該作者
感謝大大分享
回覆 使用道具 檢舉

你需要登入後才可以回覆 登入 | 加入會員

本版積分規則

Copyright (C) 2010-2020 夢遊電玩論壇

廣告合作:請直接聯繫我們,並附上您預刊登位置的預算。  

快速回覆 返回頂端 返回清單