|
CE(CheatEngine 5.6)
% p; V3 F' \& Y8 c- N7 }请到本人网盘下载:http://feilusaidi.ys168.com
! S" ~+ ?: E* Q
! ?- ^+ M# g6 vCE使用实例:4 j( m& o, D8 Q2 A7 Z
6 M. x, O( J7 F现在,我们来开始一步一步学习CE的使用吧,通过完成CE带的那个TUTORIAL,按它的要求一步一步做完,如果你做得到,你就基本上算是掌握了CE的用法了。
! h+ v! l+ @/ m/ m- K4 E
, q/ L. v; U& g# N$ m; `CE带的TUTORIAL,是英文的,不过没关系,我在教你使用CE来完成这个TUTORIAL的同时,会把TUTORIAL上面的所有英文都翻译出来让你看明白,所以不用怕。
5 |" E- j7 x* F# B# S
2 z. n( A# k. ECE带的这个TUTORIAL,是CE作者做的用来让你练习的一个程序,它里面也和游戏一样,在每一个步骤都会有一些类似血(HEALTH)或子弹数量的东西,并且你点了上面某个按钮之后,这些数值也会象游戏中一样减少,这样让你象是修改游戏一样,去找到它的地址,并按TUTORIAL上面的要求修改,当你按它的要求做到了,才让你做下一步。而在第一步时那个输入密码的地方,不是说这个TUTORIAL要输入密码才能运行,而是有时你需要从中间某一步开始时,输入相应的密码会直接从某一步开始,而不用每一次都从第一步开始的。而你每完成一步之后,它也会给你相应的密码。
& _% D# N) F/ b% W. i/ Y8 x* J9 K5 m1 w: E- o
好了,也许你等不及了,那么我们现在就开始吧。: b6 H' Z, P+ V2 [: y0 S, j" X5 I
2 M- g9 p! `( @% F第一步:
- r& k! a% y6 o" F" e. T) z! G+ ?/ x2 w5 s0 W( d, K- a# ?
先在开始菜单上找到CE的程序组,找里面的“Cheat Engine Tutorial”(以下简称TUT),点击运行。这个时候就出来这个TUT的对话框,上面一大段英文,而Next这个按钮是灰的,为什么呢?让我翻译一下上面的英文吧,你就明白。TUT上面的英文的译文,我会用【】号把它们括起来。# C* b* T/ S) [* ^3 N# H, |
( v! \' [* C- N# y【欢迎你来到CE的教程(V2.4)
4 P; \5 C) @5 h7 P" m) ^ w; a. e这个教程试图解释在游戏中作弊的基本步骤,并让你更熟悉CE的使用。
% W+ Y: Z4 T/ O5 A( N7 n
- ?" R) o: S' A& y: g首先运行CE,如果你还没运行的话(CCB:因为还没运行,所以Next按钮才是灰色的:)。7 k6 c$ x0 f0 M( c6 E3 b" O
然后点击"open process"按钮(在左上角那个有电脑图标的那个)' y( t* m' z- I; V9 G7 s& T/ c1 d
; V' C- j( X8 Q
当进程列表窗口打开后,找到这个教程,进程的名字应该是“tutorial.exe”,除非你把它改名了。选择它,并点击OK。现在先不要管其他所有的按钮,如果你喜欢,以后再研究它们。
9 N* O* V R& X4 i6 C: g9 _, P9 q$ T* e+ C- D' K
当这一切都做对了之后,进程选择窗口将会消失并且在CE上方会显示进程名。
( {. l' m7 L. \) j. k+ _: j& I4 P7 C. T) q' Q
现在,点击NEXT按钮继续到下一个步骤(或者输入密码而进到你想去的其他步骤)。8 _- E- \. v2 o F- E7 n
】- g7 T; v* L0 e" v
5 j) [% R4 K0 c2 Q# h. c) v2 p' t
好了,上面的这些英文,我翻译过来了,所以这一步应该不需要我再补充什么,看这些译文应该能明白怎么做,就是开TUT,开CE(哪个先开都没关系),然后点击CE左上的那个选择进程的按钮,选择这个TUT的进程,这样就可以点NEXT进到下一步了。3 f$ Q2 T5 b2 H( B6 m
; E. J( ?) S/ W2 R
第二步:! f/ O5 S' D! Y5 K. H- K4 V; C) r6 e* t
C1 e! @; e) z0 r) ]' i6 K1 G% _【第二步:精确数值扫描(密码:090453)
# V' P0 Y2 C$ g+ b; |2 L现在你已经在CE中打开了TUT,让我们进入到下一步吧。
: G0 M# k3 D [# X" g
/ e b4 W) S. O* E你看到在这个窗口的下方的文字Health:XXX* ^, R8 h7 T% l+ Y; E
每次你点击"Hit me"(打我)时,你的Health(血)会减少。2 U F: C* d8 i8 X+ x
& I/ j$ Z# y& z# a. B i! c% a, W
要进到下一个步骤,你必须找到这个数值并把它改为1000: z6 T7 B: F" s. S% ?
5 b. o; Y) h0 z要找到这个数值,有几个不同的方法,但我会告诉你一个最简单的,'Exact Value(精确数值扫描)':
- X/ X& x+ ?* V9 |& @7 B5 S首先确认数值类型设置为2字节或4字节,1字节也可以的,但当你最后在修改它时你会遇到麻烦(虽然很容易解决)(CCB:大家不会忘了吧?1字节表示的最大数值是255,而这里要你改为1000,所以虽然用1字节能找到,但要改却要连前一字节一起改,所以有点麻烦,不过不是大麻烦)。8字节可能也可以,如果这个地址后面是0的话,不过我不敢打赌。Single, Double, 以及其他的扫描方式不行,因为它们储存数值的方式不同。0 {6 N# k' v$ _; [4 c8 M& P
0 J: u) c D W) [' y) A
当数值类型设置正确后,确认扫描方式设置在'Exact Value'
2 t. h8 g4 }, G把血的数值填在数值输入框上,并点击'First Scan(首次扫描)'
9 s: p# b0 v } v. h3 E$ A过一会儿(如果你有一个非常慢的电脑的话)扫描完成并且扫描的结果会显示在左边(如果找到的地址的数量少于设置的数值的话)。
8 u- R/ k! Z% P0 S# E! E
& [9 X( D0 q" s' i- S- x }如果你找到多于一个地址而你不知道哪一个是正确的地址的话,点击TUT上的'Hit me',并把新的血的数值填到数值输入框,并点'Next Scan(再次扫描)'
. {! g: N) H, [* [9 u- F$ \重复这些步骤直到你确认你已经找到它的地址了(在地址列表上只有一个地址)
8 M$ K% f7 B5 H' f$ t5 t7 [/ A+ n: j; p7 q
现在双击左边列表上的地址,这样会让这个地址移动到下方的列表上并显示它的当前数值。
$ \) }9 w# i+ _双击(下方列表的)数值栏(或者选择它,并按回车),并把它修改为1000。
. k/ m4 s' _7 ]( J( s- q9 D3 G" R: N2 E
如果一切都OK,NEXT按钮将会变成可点击的了,你就准备好了进入下一步了。】 T3 X+ c* v- {1 U7 y" ~; L
/ G6 b& P' c5 O k& ~+ a这一步,也不用我再补充什么了,这个TUT已经说得很清楚,这是使用CE的最基本功能,即找到数值,如果扫描结果太多,试图改变数值然后再次扫描,直到结果剩下很少或者1个为止,这样你就找到了要修改的数值的地址,并且也就能修改它了。到这一步,你已经能对付很简单的游戏了,不过现在的大多数游戏都没这么简单,但至少你已经学到最基本的一步,就是精确数值的扫描和修改了。现在就点击NEXT进入下一步吧!' G% j' N+ n9 Y' @
. [; R6 M2 H% f7 A: S3 [/ T
第三步:& O; ^) K' d8 }# {( h9 m) \
5 Z2 X- L( r7 j# ~2 }7 B
【第三步:未知初始数值(密码:419482)) F2 E0 R4 z% T! W9 d9 ^/ P
OK,看来你已经理解了怎样使用精确数值扫描找到一个数值了,让我们进入下一步吧。
; T2 V* D2 |+ f# H
" F2 E5 \9 A' x `- L) X( _! m5 q4 P在上一步中我们知道初始数值所以我们进行了精确数值扫描,但现在我们有一个进度条,我们不知道它开始时的数值。6 i" W: d4 Q6 l- r7 P4 ]
我们只知道这个数值是在0到500之间,并且每次你点'Hit me'之后你会减一些血,每次减的血量会显示在进度条的上方。
* T( R5 L* I# m# N7 U: L. z" i9 Z/ p/ c1 f8 U [0 P5 W" I7 }+ U
同样的有好几个方式找这个数值,(例如使用“减少了什么数值”的扫描方式),但我只解释最简单的方式,“Unknown initial value”(未知初始数值)和“Descreased value(减少了的数值)”。/ z7 x: ^4 V v: `2 R: E
因为你不知道现在它的数值是多少,所以使用精确数值不行了,所以选择扫描方式为"Unknown initial value",同样的,数值类型选择4字节,(大多数WINDOWS应用程序使用4字节数据)
& _) Y2 s& s6 B H7 d3 X点击'First scan'并等它扫描完成。2 C( Y! ~6 n+ ?( j$ K
2 [: g+ l, ]1 a s9 m当扫描完成后点击'Hit me',你会掉一些血(掉的血量多少会在血条上方显示几秒然后消失,但你不需要这个数值)
- \3 }2 ~% ]# `现在回到CE,并选择'Decreased Value'(减少了的数值),并点击“Next Scan”6 k) {# R% `5 L) _ [
当扫描完成后,再次点击'Hit me',并重复上面的步骤,直到你找到了若干地址。
; d" p0 u. L5 I& _* x z9 r0 s$ \9 V Q. y& Z
我们知道这个数值是在0到500之间,所以选择比较象我们要的那个地址是,并把它加到下边的列表。. A( m1 J; W# U5 {" D- [
现在,把它改为5000,才能进到下一步。
- [3 k2 \* Y! S. v9 h】
% v( k/ z5 O8 s- c) b
9 c+ ~# Y3 T0 @, q. S4 V, s这一步,稍为复杂一点了,这是对那些血条之类的东西的扫描。作者说知道数值是0到500之间,但没说是怎么知道的。我的看法是,这东西一方面靠猜,另一方面靠试。你也许会说,比如血条或蓝条,上面或下面不是有数字吗?是的,有些有,有些没有,但有时,血条上面有个表示血的数字,说血是548,但你就知道它是真的按这个值存在内存的吗?不一定的哦,很多游戏的开发者,可能会用某一个方式存真正的血的数值,而用另一个方式显示,例如,最简单的就是,真正的血是你看到的数值的3倍,例如上面说的548,其实在内存可能是1644,而当它要显示的时候才把1644除以3然后显示出来,所以如果你受这个显示数字的误导,结果就有可能找不到真正的地址。所以关于那些以长度表示的数值,一般还是靠猜,然后根据猜测来找。还有,CCB友情提醒一下,其实有时在找到的数值比较多的时候,试试在扫描的过程中,确认数值确实没改变的情况下,多加几次"Unchange"(无变化)扫描,这样可以再减掉一些无关的结果。另外,其实在这一步,如果你够聪明,每次点了Hit me之后记住血条上面显示的减少的数字,再在CE中输入刚才的数字(负号不要,负号只是表示它是减少的),并选择'Decreased value by',即“减少了什么数值”,这样也能更快地找到准确的地址,但这种方式是在要知道减少了多少这个具体数值才有用。好了,继续下一步吧。* o e5 R* ~9 `( y+ T) [7 G
" X# P. P; x# } T `* E第四步:
3 L" y9 U. S% t7 [* V5 r
- F4 x; ^% w% w: @4 O' @- S) c【第四步:浮点数(密码:890124)
$ @( u* B) v0 q$ b! O& }- ^* S在前面的教程中,我们使用字节来扫描,但有些游戏使用了叫做“浮点数”的记数方法。8 A a$ i. e2 q( Q
(可能是为了防止简单的内存扫描)
7 T2 z1 \- D. N- h! \& |浮点数是带有小数点的一些数字(如5.12或11321.1) w. V- d+ u+ {0 }- ?3 e% o F8 y
$ v7 f6 H. P Y+ `如下边你看到你的血(Health)和子弹(Ammo)。两者都以浮点数储存,但血是储存为float(浮点数)而子弹是储存为double(双精度浮点数)(CCB:这是数据类型的术语,float和double都是浮点数,但float为单精度数,而double为双精度数,它们在电脑里面占用的字节数长度不同,而所能表示的精度也不同,看不懂不要紧,反正知道这是两种不同的浮点数就行)。
3 m0 `2 U" _' B2 X点击Hit me可以减少一些血,而点击shoot(CCB:其实是Fire)可以用掉0.5的子弹。
6 Y4 {, Q* b( e, X+ k# h. C$ I
/ \; x4 a' N6 {4 q! o6 {$ Y! K3 T你得把这两者都修改到5000或者更多才能进下一步。
) X6 h8 D# c: y2 D- v2 A; o. p: g( d- G
精确数值扫描方式在这一步能工作得很好,但也许你想试试其他的扫描方式。(CCB友情提示:扫描子弹的时候试试'Decreased value by'方式就不错,数值填入0.5,很快就能找到)
1 S5 z: i0 \ @) A8 H】
8 \5 y; i/ X' m" X! u" v4 k* l" X. B* |6 b$ T9 c1 {3 i' ?6 v
这一步,其实也没什么,只是让你熟悉不同数据类型的扫描。再次提醒一下,其实有时游戏的开发者为了不让你太容易扫描到数值的地址,所以有时故意颠倒黑白,例如你看到有小数的地方,有时在内存却是用整数来保存,而你明明看到是显示为整数的数值,却有可能在内存中是用小数来保存,所以有时不要轻易地被你看到的东西误导,特别是在多次搜索不到结果的时候,有时要换换别的方式,不要让狡猾的游戏开发者骗了:)。+ P" L6 _. y% @ f# f
& s8 v9 Y v/ E$ f第五步:# g) e2 ?; ?2 U8 o b
+ W7 \; _7 t5 X0 S. `【代码寻找(密码:888899)) I# ]7 `3 G+ p4 A+ U* U& [
有时一些东西的保存位置在你重新开始游戏时会改变,甚至是在你玩的时候也会变,在这种情况下,你用二件事仍然能做出可以用的内存列表。
9 r3 t) S$ C$ b+ R" h% j在这一步我会描述怎样用寻找代码功能。1 w: F' T5 v/ W* H( W
* X9 R5 R. @7 A6 O下面的数值每次你开始这个TUT的时候会存放在不同的位置,所以一个普通的内存地址列表将会不适用。
, j- y3 u( k( a% Y( q首先找到这个数值的内存地址(你能进到这一步,我假设你已经知道怎么做了); a" q6 }! ^+ a4 X
当你找到地址后,右击CE中的这个地址,并选择“Find out what writes to this address”(找到是什么改写这个地址),一个窗口将会出现,上面会有一个空的列表。
9 l; d! L/ h& E0 j1 f0 i' J然后,点击这个TUT上的'Change value'(改变数值)按钮,回到CE,如果一切都做得对,会看到一个地址和一些汇编代码。
3 h. X" w3 u6 \, \' b点击这个地址并选择Replace(替换)选项把它替换成什么也不做的代码,这样还会将代码地址加到高级选项窗口上的代码列表(它将会一起保存,如果你保存地址表的话)。 [$ Q& `/ B$ \6 O4 m9 l
2 j: v1 P9 |1 C6 M$ A7 [2 H
点击Stop,这样游戏(CCB:指这个TUT)将会再次正常地运行下去,并点Close关闭这个窗口。9 M# L$ {, m3 Q( ^; [
现在,点击这个TUT上的Change value按钮,如果一切都做对,NEXT按钮将会变成可点击的了。1 V2 Z2 r2 A7 ]% `8 N
" `8 i$ G9 O4 n( w' ^* D5 C3 x
注:如果你以足够快的速度锁定这个地址,这个NEXT按钮也会变成可见的。7 }3 S7 ~! ~0 I% T
]】+ I% u. Z( D+ H3 K; A# J! `9 y$ O
3 B( }; T2 _8 a越来越精彩了,现在不但教你找地址,还教你找那条修改这个地址的指令了,虽然,你还不太清楚怎样手工修改找到的地址,但至少也比单纯地找数值的地址并修改和锁定要好一些了,不是吗?别急,更精彩的还在后面呢。3 L/ y, i+ L$ o% N6 e& U+ V' f
2 d0 H3 k# ?! C+ w第六步$ x; z6 Y! ?% k' E& \
5 b- T) }, F! \4 _# a% D7 F
【指针(密码098712)
/ a; w' G! m$ V/ h1 S: r3 X在上一步我解释了怎样用代码寻找功能对付变化位置。但单独用那个方法不容易找到地址来修改为你要的数值。
4 B1 i" j; n/ X c: S- v$ g3 {0 R# z这就是为什么要用到指针了:
' j5 w- I+ U9 x5 s- a% d: N$ _6 ]1 J4 O) T
在TUT下面你会找到两个按钮,一个会改变数值,另一个不但会改变数值并且还会改变数值在内存中的位置。
: P E! D/ R% R1 K6 c( e" l3 c在这一步,你不需要真的懂汇编,但如果你懂的话会很有帮助。
/ T! p4 Y' n3 w9 g3 m
" J: f" |; R, X9 g首先找到数值的地址,当你找到后,再找找是什么在改写这个地址。再次改变这个数值,这样会找到一个代码地址,双击这个代码地址(或者选择它并点击More info),这样一个新的窗口会打开并显示详细的信息告诉你当这个指令运行时会发生什么事(CCB:这个新出来的窗口上,那条指令会是红色的)。如果这个汇编指令里面没有包括一个在方括号中的东西,(CCB:说明这个不是我们要的)那么再看看代码地址列表中另一个代码地址。如果有方括号,就是说CE认为找到了数值的指针了。" s( b: {2 y+ J4 J; P- N- \
回到CE主窗口,(你可以让那个扩展信息窗口开着,但如果你关了,要记住在方括号中间的内容)(CCB:要关了那个有代码地址列表的窗口,才能回到CE主窗口,但扩展信息窗口可以不用关掉),并做一次4字节的扫描,扫描扩展信息窗口告诉你的十六进制数。(CCB:就是方括号里面的内容,如果方括号里面是[eax],那么看看扩展信息窗口下面EAX=后面的数值)。当扫描完成时它可能返回一个或几百个地址。大多数情况下你要的会是最小(CCB:指地址最小,也就是排在列表的最上面)那一个。现在点击手工添加内存地址(Add address manually)并在pointer(指针)这个选项上打勾。
* z2 l! I0 n3 Q7 R% f) k# n' ]) y) G) p9 u$ g( Q
这个窗口将会改变,并允许你填入指针的地址和偏移量。& a2 w1 J5 v% ~2 w
在地址那里填入你刚才扫描到的地址。/ ` j) D. B/ J8 C7 z- b
如果汇编指令在后面有一个计算(例如:[esi+12])那么把数值填在后面,否则让它保持0(CCB:就是如果有类似那样的计算,把12这个数值填在偏移量(OFFSET)那里,否则那里填0),如果是更复杂的指令,看看它的算式。' Z1 a+ H# P9 a) y4 R
& t) d7 b* m3 Q- g+ o0 _+ O4 U7 q举例说明更复杂的算式:! Y* Q# o! E0 v
[EAX*2+EDX+00000310] eax=4C 并且 edx=00801234.(CCB:这时各个寄存器的值到底是多少,要看扩展信息窗口下方,那里有各个寄存器在执行这条指令时的值)$ w: j/ r& W) x7 m) s& U8 J+ P
在这个情况下EDX会是数值的指针,而EAX*2+00000310则是它的偏移量,所以你要填的偏移量会是2*4C+00000310=3A8.(这些都是在十六进制下计算的,使用WINDOWS的计算器在科学方式下用十六进制计算)。+ |& x" i& o, f/ t: w
! i# }0 A# P' W& r, j* t5 e. V回到TUT(CCB:?),点击OK,这个地址将会加到列表上,如果没搞错,将会显示P->xxxxxxxx,xxxxxxxx会是你找到的数值的地址。如果不正确,那你一定是哪里做错了。
0 [/ R! Y# Z- w* h2 d现在,使用那个指针改变数值为5000并锁定(就是在下面的地址列表中,点最前面FROZEN那一栏的勾)它,然后(CCB:应该是这里才回到TUT吧?),点击'Change pointer'按钮,如果一切正确,那么NEXT按钮将变成可见的了。
# c5 L4 l+ l1 G% S2 @
3 B. e( w8 Z+ Y. \% l额外信息:
8 ^" P, V+ R2 o2 D1 h: N& A( W S在这个TUT中,事实上数值是由一个指针指向另一个指针(CCB:再指向真正的数值,就是使用了“指针的指针”,有点象绕口令:),但要完成这个TUT只需要一个指针。要找到这个指针(CCB:是说要找到指向指针的另一个指针),只要搜索是什么改变那个指针。
( r i% F' U, _$ n( g! _+ ? @如果你懂汇编,你可能会看到类似这样的:
( }* s' j; u/ f$ Imov eax,[ebp-4]5 Z! i/ s0 a a' j9 d
mov eax,[eax+310]$ ?/ V. Z# r( z9 X+ n% T
这些别搞混了,只使用扩展信息窗口告诉你的数值。ebp-4指向堆栈中保存了指向这个指针的指针,但堆栈的位置总是在变化,所以不要搜索ebp,而要搜索eax的数值。! B2 F9 @' i! e# B' F
】
7 X8 ]- K A* y0 x1 n* w- Y0 I
这一步,确实就够复杂了,也许你到这一步真的有点想放弃了。不过,如果我告诉你,这是这个TUT的最后一步了,你还会想放弃吗?呵呵,坚持啊,看不懂就问,把CCB这家伙问倒了才好呢:)。其实这就是对付DMA的方法之一了,就是先找到地址然后找到指针,找到指针就好办了。# R: ^: Z# E( x$ a+ I. c
+ |. i9 `% O, D0 w: P; o% k第七步 密码=013370
4 o. Y, x4 ?; F+ C( S* S7 v5 L5 e' l" Q- j* o- R6 E; A. X
代码注入是一个将一小段代码注入到目标进程中的技巧,然后使这个进程执行你写入的自己的代码。
. ~5 ?. I- x; r6 q/ C$ c0 Q2 r0 j: I
在这一步教程中,你将有一个生命值和一个按钮,这个按钮每按一次将减少1点生命值。你的任务是使用代码注入来增加这个生命值,使得每按一次按钮增加2点生命值。, x w2 m: X; F3 l/ f+ Y1 R
: s) I* M' n$ G( ~( _- E
开始查找这个地址然后进入“找到写这个地址的东西”。6 T, x I- \" s& O
然后减小生命值,当你已经找到地址后,显示反汇编程序(Show disassembler), 并找到这个地址,然后打开自动汇编窗口(Tools菜单->Auto Assemble)(Ctrl+a)
2 K9 P) W0 `" b% T, u/ h( C J在tmplate上点击然后再点击Code Injection,并给出减少生命值的地址(如果程序没有正确填写的话)
6 o. h9 _! R+ q+ F1 v1 P: I; d+ |( m$ h5 N6 Z
那样,将产生一个基本的自动汇编程序窗口你可以用于你的代码.
; B1 J: e( }' y# r( y3 a& k6 [' q* v' _+ S
注意alloc, 那将用于为你的代码分配一块内存, 而在Win2000系统之前, 这种行为存在安全隐患,是不安全的(HZH:在Win200以前,对系统内存进行分配及代码查找之类的操作,可能会导致系统崩溃),幸运的是这种情况在win200以后的版本得到改善.
3 x" Z2 H$ R6 U) D$ T
) V% A5 \# c* c/ ]2 ]" r; j$ O _8 |同样,也要注意line newmem语句及原始代码,以及文本"Place your code here",正如你猜测的那样,在这儿写下你每次增加2点生命值的代码.3 }: V, Q& E0 d f- g/ F/ T7 A
在这种情况下,一个有用的汇编指令是"ADD".
& H A6 `* x; u# p) Q下面是一些示例:
! n! }7 S- g# i/ x- m. ]5 f9 Y5 W"ADD [00901234],9" 使[00901234]地址的值增加9
' E @( F5 T5 h; v! y& i F+ b0 x% ["ADD [ESP+4],9" 使地址指针[ESP+4]的值增加9
4 p$ L5 I9 U6 X# \% q! }1 R& x/ R! D. i1 e- y, N
注意:
( _" k$ q5 m; a/ \! u7 Y推荐你从原始生成代码中删除减少你生命值的那行代码, 否则你将不得不增加3点生命值(你增加3点,而原始代码减少1点,那样最终结果是增加2点),这样可能会造成混乱.7 f+ u7 g) v/ X- N9 H0 J/ S! x
( A' \, p" P, C% q7 _注意2:
' D: F2 u$ c) N# M3 ]5 a/ Y在一些游戏中,原始代码可能存在在多指令之外,并且某些时候(并非一直如此),这可能会发生在其他地方跳转到你的跳转指令结束,那样将引起未知的行为.如果这种情况发生的话,你通常应该查看附近的指令,查看跳转情况并进行修改,或者选择使用一个不同的代码注入开始地址.4 K/ |3 X% S5 p5 u
" u( C. X+ E, y6 R
最后,点击 Write code.
- n6 D+ b( q/ W, p* N, `. r! _7 g% ?/ J# S/ M
9 i+ u+ C9 V e- s# I# m* v
第八步 多级指针: (密码=525927)
4 t% t4 X+ B _这一步教学将会解释该如何使用多级指针。3 p. Z$ _1 `0 y
在第 6 步的教学中你应该了解到了简单的1级指针的概念和用途, 以及如何由数据的地址找到真正的基址。0 U6 U8 T0 m) u [. a) }
在本步教学中,你将面对的是4级指针的挑战。它将是一个指向指针的指针的指针的指针,最终指向表示生命的数值。
" F4 z* C/ M% M3 Z3 O1 L) P1 s5 ~" F2 d" a' j7 m( }- p2 B
开始的几步与在第 6 步教学中操作基本相同。找出是什么存取这个数值的,然后检查指令和可能的基指针数值,以及它的偏移量, 并将这些数值填充或把它记下来。但是在这里与第6步教学中情况不同的是:你找出的数值其实也是一个指针。你必须依据这些数值,使用同样的操作方法找出指向这个指针的指针。找出什么访问你发现的那个地址,审查汇编指令, 留意可能的指令和偏移量,并在下一步查找过程中加以使用。这种过程一直进行,直到不能更进一步查找为止(通常当基址是一个静态的地址时,这个地址将以绿色显示)。& @# M5 x) @% L8 m. Z; Q: n& I- g$ `
: e7 W( {% N) A4 r7 q# ^点一下“Change Value(改变数值)”让教程程序改变下生命数值。! ^7 D8 Q1 q! |: N! s" i% e3 N
如果你认为你已经发现指针路径单击“Change Register(改变寄存器)”按钮。指针和数值将随之
, i3 v% f6 E. \& }( z& j5 r# N4 @改变,并且你将有 3 秒时间来锁定地址到 5000。; J: N& r# ?( ?
9 L+ T ~+ X8 _, E( u
备注1: 这个问题也可以使用自动汇编程序脚本或者使用指针扫描器加以解决。# r) `- @+ i" q7 X5 G) y$ c' u, Z
3 a4 z( P, w9 C- o* w4 e
备注2: 在某些情况(像本步教程)下,一个被推荐的做法是:改变CE软件的设置中“代码查找器Code
6 [9 n' ?8 G; {9 b6 _Finder)”中的相关设置。这样,当你遇到像 mov eax,[eax] 的指令时,调试寄存器(Debugregisters)将显示被改变之后的值,使得能利用这个值更容易找出指针。$ V+ |: D) ~7 H0 l
" v: ]9 g1 u, g0 X
备注3: 如果你仍在往下读。你可能注意到,当你查看汇编指令时,这些指针是在相同的代码块位置被读写。这种情况并不总是会发生,但是当你在查找某个指针遇到麻烦的时候,真的有很大用处。- f6 P7 w' t: D6 {" d* K
0 s' N! j0 A. Q9 R) u第8步教学完成步骤$ O# j- n* D4 V8 C
) u7 Q6 ?% `/ k1.搜索生命值6 H7 n1 s9 w# ?! ?
* w1 \9 j, ]5 t" Z2.将找到的地址加入列表; w$ c! y& `7 J, T9 u8 i
) i, H9 m1 k4 a# u1 _3.在地址上点右键“找出什么读写这个地址”,然后“change Value”4 M0 A9 h/ {3 F4 v" I
. j9 z) l4 D, E& } q: L$ F& p& }: Z4.mov [eax+18],esi ==> eax=009ca668(大家找到的肯定不同,后面有说明)==> 搜索009ca668 ==>009ca5ec
' T7 ^) m3 W+ V/ J0 E* W
. L5 i1 u6 l" X: s% [4 c6 w5. Add address manually ==> Point => Pointer: 009ca5ec, Offset:18 => OK =>P->009ca680& c% M% A- i8 E; ]4 E! q/ v. w& v
" A- z0 B% Y" G1 x7 }# S) s6. 在列表项 P->009ca680 上点右键 => Find out what accresses this pointer => Change Value2 ]8 E H* P& q3 [6 d
7 s5 F( Q( [5 ~/ f7. mov eax, [eax] eax: 009ca668 ==> 搜索009ca668 ==> 009ca5ec ==> 009ca5c4
( {; J1 d2 i7 j0 W4 T/ s" Z$ P e. `7 l3 O+ z: \1 P1 B; G V2 h
8. 编辑列表项 P->009ca680,添加指针项,Pointer: 009ca5c4, Offset:0 => OK$ k5 @" B* Z0 |9 N$ |! e l, _
7 d% C+ D2 v3 E$ z) f" j; ]' i) f9. 在列表项 P->009ca680 上点右键 => Find out what accresses this pointer => Change Value
. A2 H4 A; U0 ~8 Q( F# O
6 \0 m; h0 y2 e* |10. mov eas, [eax+14] => eax: 009ca5ec => 009ca5c4 => 计算:009ca5c4-14=009ca5b0 => 搜索009ca5b0 => 009ca544
5 a" ]1 D0 C# u. z% `1 e2 Q3 z& @$ Q
11. 编辑列表项 P->009ca680,添加指针项,Pointer: 009ca544, Offset:14 => OK K$ y( T- E" `6 _1 K7 p9 G2 s$ K& z
2 W# ?8 j2 F* s$ q$ L12. 在列表项 P->009ca680 上点右键 => Find out what accresses this pointer => Change Value
+ N8 T k0 e* V! Y
6 p9 d- |, @( d+ X, R( U9 L13. mov eax, [eax+0c] =>eax: 009ca5b0 => 009ca544 => 计算:009ca5b0-c=009ca538 => 搜索009ca538 => 0045cc18(绿色显示)5 b }1 T1 t' S q1 [$ @
1 I! c+ h" f* ~$ {7 G
14. 编辑列表项 P->009ca680,添加指针项,Pointer: 0045cc18, Offset:c => OK
1 d! O( e; s4 `2 a$ M6 Z3 ~; d% o2 |# ]7 m8 d3 e4 P, B
最后,将数值改为5000,Next; y. E/ P+ z) A. D- s+ N5 z
# z0 U5 x1 t/ z. a! a
Well done, you've completed the tutorial of Cheat Engine.
" p% I( P7 R' S" m7 O" DJust play arround with the tutorial and learn how the other scanmethods weor.
L! l" c/ k4 F' A4 Q* ~/ V% W: I
0 H( Z/ q, c9 \6 J# Z8 A7 s' m
关于第8步的补充说明:
; {8 O v; \' _) X; d, e4 H& i3 s6 ^4 G4 ?$ E0 D F+ Y0 j( e
除了最后以绿色显示的0045cc18值之外,其他的Eax值都要以你自己找到实际数值为准,步骤中的数据只是示例,重要的是原理方法掌握就OK了,千万别以步骤中的值来找哦。
1 M) D3 q/ ^: x6 u k另外 本关可以通过备注里提到的使用指针扫描器等方法加以解决。 |
|