设为首页收藏本站

EMU618社区

 找回密码
 立即注册
搜索
查看: 1555|回复: 19

[研究] 菜鸟hack勇者斗恶龙4(dq4)fc英文版实践(实际上记录自己过程)

[复制链接]

签到天数: 31 天

[LV.5]常住居民I

发表于 2012-11-25 11:02:57 | 显示全部楼层 |阅读模式
本帖最后由 sdiencelee 于 2012-11-29 18:38 编辑
6 p( Z7 F% k  U: ~$ Z, A% O2 [% N7 Q9 E
由于此处无法上传本地图片,所以只能先在其他地方发个贴,贴过来图片,http://tieba.baidu.com/p/2007950726
9 _% K3 L- K. u4 W% R0 |" h  s- Mdq4是我玩的第一个英文rpg游戏,当时2001年左右,刚大学毕业,用fcsim的模拟器(dos的模拟器,虽无即时存档功能,但有电池存档,不至于心血白费,方便快速关机,逃避家长偷袭,也是那时候唯一可2 m6 z  v, x% V: D
以玩霸王的大陆模拟器),多亏是英文版,还可以无攻略通(其实那时候也不太知道有攻略这回事)有人当此为废话可以无视,看下面的。; d' {/ }" m0 v) o4 W* x( u* U9 k
首先
* A- W2 v" o- w# y; E; n一、为debug做准备找到1.virtuanes的debug版本和2.比较新版的fceux,这两个东东因为互有优缺点,( W# p# Y7 t3 ?
所以,均准备出来0 d+ A+ j6 a# o' Z
8 n6 M  ~5 K* p& ~8 a& m2 F
【补充知识,对于ec码与vnes及fceu等模拟器的地址之间有如下关系
" H9 _5 Z. D- n5 p( @对于前面的那段,ram:(0-7ff),ec码地址与模拟器地址相同
! R9 _6 J2 c; B* F+ Q" X对于后面的那段,sram :ec码地址为800-,模拟器地址为6000-,可以看出两者关系 模拟器地址=ec码
1 H( c( P( V  d+ ?( A0 W/ a) O" j2 k  b; v3 E5 ?# ~5 x. j- X! g
地址+5800】
5 t) w/ a$ w1 O我们先要hack最贵的金属盾(50000)那个东东,之所以选择最贵的,因为在设置断点追踪过程中,常会$ K; U! l: L7 F
# W" Q% R5 T8 a4 Y8 V1 I1 ~+ e2 ]5 {
再次追踪到零业地址这个变化频率很快的,就会出现断点跳出过快的情况,所以,先找最贵的,利用工
5 H" W# ^' j  e0 g+ |  V' }
9 J$ H! ^8 Y$ U9 D+ X; O具知道50000的十六进制为3c50(计算机记数为503c,具体参见6502大奥秘)
. Y8 m; v0 s, W! W" T之后执行到将东西卖给一个人后,当然了,首先作弊将代币个数调到可以买这个金属盾,其实以后往往" C# G# d) z7 w5 C* E

$ T9 y+ n% l7 k) T2 V3 x% G还会特意将东西,调少,干不动某事,其实程序先有指令判断是否可行(在此进行追踪),这样以后的
" n, N3 g: V0 f, o  X- i2 T
+ F" {. F) w8 u/ h6 i  D进程无需看了,会减少不必要的过程。8 S0 |5 P, m2 p: l/ z+ J# {
发现,游戏停止,指令方框内将地址$62ad减去$fd的值在赋给$62ad,(及$62ad=$62ad-$fd),至于我
$ a3 U" C. B0 I- ?- q* y0 |$ j8 m; S7 U( S
们找的这个对不对,我们点击条命令后暂停,+ k& L  N3 i6 s' m6 A; C4 i
二、其他工具hexedit类如ultraedit(其他亦可),一个16进制十进制等转化器(无需手算,知道了具# |7 g( S9 A! R; F; E8 t8 M
体如何做,不必人手做!!让我想起来一个爱因斯坦的典故:大致意思,一个人问爱因斯坦有个著名的桥多长,爱因斯坦说不知道,可以查书问某个海有多宽,还是不知道可以查书,最后那人说什么都不知道,为什么你那么牛,你脑子里装的什么,爱因斯坦说我只思考和记忆书本上没有的东西,跑题ing)  R( k1 E  S- `9 d3 ~
其实,以后必须要看6502大奥秘这个东东,但是直接看很烦,我也是先看教程,在看6502大奥秘的。. w& I6 V) x5 ~3 x1 s; a
这个实践应该将菜鸟的本人所有的心得,错误均写出来,但是由于最开始的所谓的入门,先找一个最简
/ D0 X- _8 v2 M& Z6 [8 z+ ?0 K  P5 \' ~" i1 B: k+ H

' @  I* r5 {7 Z- x2 H: i: |, ]/ E2 N0 ]6 Q5 E9 _  P
单开始hack。就是赌场内的物品价格4 q7 g4 c) I& t0 V# A4 ]9 ]. n5 Z, Z

' D% G7 {5 U$ U' x8 ~+ M$ }5 N点击后发现正确,0 P. u' l' n/ t4 k" N

/ f$ d/ N  w+ o# u
3 O; M, }0 a- d$ B+ y; _4 X& f; _# m3 w% g0 O6 e
进入实践,首先我们要设置断点,用vnes(virtuanes简写,那个模拟器简写为fceu,下同)
; g) _7 s) y/ i& w0 s/ M3 A通过查询或是ec码,知道要在62ad上设置断点,先存个即时存档以便追踪过程反复读档首先vnes点开ram; _5 n+ H% [/ s: x3 Q! u$ ~3 J
0 u* F2 q" L* y1 g
及debug,注释内出现 如图填入

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-25 11:09:42 | 显示全部楼层
我们接着追踪地址$fe(之所以追踪$fe而不是$fd,因为可能$FD也被其他过程调用,而$fe要在调用$fd. r& S" D$ F0 u. Z/ {1 g$ O
的基础上,所使用的数值必须是对于255才可能调用,避免了麻烦。),点击运行,读原来的档,注释内
% Y6 I9 \+ T2 ^8 n6 L9 [6 E2 b# y. m出现填入[00fe]=a=0x3c(意思为将寄存器a的值3c赋给地址$fe,图如下444444444444444444,我们发现又
, G( y! J( S6 b" P2 z! c: m! A要追踪$01.别忙,我们发现就在前几个指令上有给$01赋值的语句,而且值也是503c,该句为lda b34f,x 就是说将$b34f偏移x(寄存器)后,去该地址值赋给寄存器a。其实一般说来,追踪地址到
. I! N2 X. S& q+ E8000-bfff内,就可以hack rom了(这一点在fceu很明显),在memoryview找到$b34f,之后,左右看看0 o2 E' g  b0 b* b6 J( d2 F6 G
(其实知道x寄存器就可以了,不过免了,比较容易看到),将其改个数测试一下,成功。[img][/img]8 ?2 L" ^- i% U0 y" q
& ~. M$ q& _. h! w
我们记下来pc值以便后面使用。
7 h0 V6 g7 @( {* K' V7 w) M- L3 A下面我们在此查找4000的流星手镯,这次无需设置读写断点了,而是执行断点(fceu的术语),1 B8 \9 v) c2 u, M7 o& i$ g: b) C

: V  B0 C8 E4 ^" T7 u' c
' i6 G: J1 M/ ^. ?点击运行读档,后在图内pc填上a484,同样的操作买4000的流星手镯,模拟器暂停,在7 T* F) n: {, n
# ^4 o* Q( W1 E9 I$ z# F$ c- `
内存上,看见A00F(就是4000)和刚才的中间差了一个地址,再按照规律向前看,则出现C409(2500)
  V$ f* }7 I& x! o- j. ?$ z8 ^; C
等,我们改一下,
9 @7 J  t0 t; _% O/ C/ p" P# S! o& l4 I; w

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-25 11:11:33 | 显示全部楼层
之后我们再次跟买东西的对话,发现修改成功(可能是我改错位置)嗯,修改成功,
$ U5 F$ v- q- ^5 c
2 r8 N4 ^. `/ {$ J之后我们用ue找到对应位置,发现有两处,想到dq4有许多版本,512k的,1024k的,这个是1024K的可能出现重复数据,2 P, v8 a! j* v2 |7 H4 J
(最开头的是分别是5和d,相差8,基本确定为重复数据),对此,还可以用fceu修改。执行断点写入B333(前图中有),之所以不写a484,因为fceu会将a484那一段代码全部写出,即使被跳转而没有执行相关代码,在此处不方便查看。5 b% i7 B3 f: `
设置好后,找个东西买(由于没有fceu没调代币,只能买最便宜的)

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-25 11:13:31 | 显示全部楼层
(试了试转帖工具,很好用)* H& }; M9 M, y9 g! \
暂停于此,十六进制编辑器,转到B3F4(应该是B34F,差不多,懒得再截图),之后,点击要改的位置,点击转到相应rom位置
7 i9 e1 `* z& K. y5 r$ s- Y5 D/ l, Z) u. Q
改一下数值,保存另一个rom(直接保存原文件,往往当机),
2 g4 Y+ V8 P6 M4 M; X. y  b) L关闭后重新执行,看一下效果: S) J* D5 Y& g0 X7 p4 @
终于改成了。以后我会将实践的普通物品的写下,应该会简略些,除了比较不一样的,会配图,其他只是写些追踪的地址及指令。普通物品,最开始着实难倒我了(因为没有转到好的追踪方法及没有耐心),连ue直接查找,15000的dragon killer用3a98和983a两种改都无效,没办法,慢慢跟踪找到了,(待续)
: l/ A  u( H. e# Q

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-25 11:27:48 | 显示全部楼层

huchuan

本帖最后由 sdiencelee 于 2012-11-29 17:03 编辑 0 @' e: H  D, Q2 u1 h

5 z& _+ B$ k! N# A9 D第一楼不知道为什么文本有出入?
5 ^# E) Y' T# ~" g  B; Z
8 S  I9 e) ]! R2 H/ W* s; S0 V0 m
不喜欢在加新楼,再次写入自己的。
8 m+ J( K: A* [; A7 G# i6 n( h这是怪物数据的搜索,由于在百度贴吧说有没有一个一战1千经验的hack,正好适合我这个菜鸟练一下。搜索到每次战斗后的经验,
# `+ e3 j, S! X( Y( i: E6 w3 z7 F5 _5 P* n  ]9 C; l' |: p
为地址$7203,对其追踪,发现,$7203会将每一次打死一个敌人的经验累加起来,本来想改一下那个累加的值,最后的语句改为赋给1000' D) L+ R0 [" V/ R

- n' X3 U" q# T# R# O的经验,多赋值几次也没关系,没想到出了错误.索性先追踪,怪物的经验值,以便找到怪物的其他信息,$ c3 X* p) {: o3 D% Y, i5 Z3 W2 P1 F
想了半天,就是10050(4227)的metal babble符合要求,9 G' ~9 W" W6 |- P
5 255 65 1023 150 10 10050     Gardenbur(5), Final Cave(5), Royal Crypt(5) (怪物信息)
7 e0 T5 S) I* c0 w1 u值比较大(255以内),2字节(上下看看可以更加确认所追踪非误),) E$ |4 I# q2 O! i( [; W  r/ \( {
再次使用金手指ec码,72e4锁定为8会心一击,6E45敌人代码锁定为75,6E49敌人个数锁定为8,遇敌存档,
7 d$ S8 f& r( Y设$7203为断点,最后追到$76,再追$77,vnes注释内写[0077]=a=0x27,没有停止,最后看了看 改为 [0077] 0x27,追踪到$20,: P& W  A7 |4 I8 M
填[0020] 0x27,停止后,下移10行,如图,; Y/ ^6 y) ~0 x. {' p9 V' a
+ T( ~( V( d% H7 M" l" \# |" v1 s
发现ram内8A50,行与提供的数值符合,应该找到地址了.记住这个$C3FD为执行断点,以便找到将其他一
3 H& H0 P$ b+ }6 V3 B, p. u6 ?8 F% I' D; P6 R% @( @& y

1 }/ \, F9 T0 T8 h6 [" J9 M: W$ f9 b些敌人数据./ z+ m" Y: Y5 k8 j* K! r( U
又换回了工作单位,还得重新两边,下面,看看最开始的怪物,数据,用fceu设置$C3fd为执行断点.将敌人定代码00,个数8,有些异常,先想想,找找天幻的专门的东西。

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-25 17:14:05 | 显示全部楼层
找dragon killer(屠龙),来到rosavillage,在即将买屠龙的地方存档,先将6157金钱地址作为断点,买入后停止在pc为86ca上,6157的值来自$00,由于一抬眼看到了3a(15000计算机表示为983a),在此将指令行上拉,以便看看有无98出现,为此先点停止刷新,在拉上去,看方框中内容,意思是将地址$72的之后3位减去地址$76的三位在赋给地址$72(后三位),可以追踪到$72是地址$6157赋值过来的(已经对此hack无用了),地址$76正是dragon killer价格,之后将其设为断点(图没注意被覆盖,补个图),1
& s3 ~) Z! j- }- f: I9 n% M" q追踪到pc值为821a,数值来自地址$70,发现以后停止都在这个点,如此再次继续,写$70=a=0x3a,到8D58,来自$03C2,以后表示为(8D58:$03C2>),和(BAA9:$0001),经过点击执行后5条命令后暂停,排除出PC为8D58的可能,之后,再次追踪,用如上法排查后( W( Y" R+ H7 B) y- v1 q
(A06F:$6E13>),# g( j6 ~; \  p- @! O
再次后,我们将金钱数改为14999,正好钱不够,停在此处,发现方框内语句为将$6E13的值加上 $01,x(使用寻址方式,可以无视)的值在赋给$6E13,而对于$01,和$6E13再次追踪,发现,均来自地址6E13,而且,前面的PC因为在(A06F左右),这样我们只能向上拉,最后看到,先停止刷新,其实我在原来过程中,是一步步追到此处得到的,(8bde:$8DE2,X>),之后找到对于ram附近,经确认那个8f对应为方框中地址,之后由于看见前面有3X aX(两位的头不是3a码),所以也就顺便将其改了,四位全部改为11,不知道会有什么效果.读档后,发现价格改成了,*****记住pc值为8bde,测试,读档后再次跟老板说话,哈哈,改成了,变成了17000,虽然不知道如何改对的反正是成了." a6 ~" H8 B4 \# g8 q/ C% h, v. U
现在我自然是稍微知道如何成的,其实,这段就是我最开始的hack过程,我早说过,我会本人在hack过程中的错误也会说出来.至于如何成的,请见后.其实,只要按照那个执行断点继续下去,也会慢慢明白的.待续

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-25 17:16:53 | 显示全部楼层
为什么百度老出事、贴个这个图挡住,什么意思,

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-26 07:24:06 | 显示全部楼层
之后,用fceu将对用的rom地址改过后,成功了., f7 y4 h3 w* h
我们也没有看到改了那么多数,dragon killer的几个有点类似我们预想的,我们再试试8000的睡觉剑(这次只改对应那一个地址),设置执行断点8bde,再次买东西时停止了(A=0x37?),为什么,先让他继续吧,去买8000的剑,有时候会该暂停的不停了,不知道为什么,反正将debug窗口,关闭在开启就可以了。在直行5条后。如图,方框内,中间的 AND #$7f什么意思,就是寄存器a和7F做逻辑运算"与",就是屏蔽a的最高位,即a取128的余数.D0就成为50,不管他,先填个数吧,写22吧,最后成了3400,对了原来改11的时候dragon killer为17000,似乎相似,好这次直接7500对应改11,也成了1700
5 X. _  d5 Y( P: i6 }4 W* i: M/ C! \  Q  s3 g/ s% B- F8 g: f

5 G) X# q5 m& z* P. b- H差不多明白了,一个地址对应一个价格,而且发现,17正好是11的十六进制,34正好是22的十六进制,至于为什么会加不定个数的零,我也不懂,这样,再想想开始那个37就是55,应该是5500的东西,为了验证这个想法,我们查一下物品的代码,查9 k) t7 e' T" p7 D9 ^( K* e' \/ t
ec,: W! _+ v4 ^/ C8 ~
曾木棒=8cb,0
$ A8 l, b  M/ y! i木棒=8cb,1# {( D; ]6 \( G; y
铜剑=8cb,25 x6 R, a4 c1 v5 q
铁爪=8cb,3
% h- k/ H+ [0 n) S锁链镰刀=8cb,4
4 B# R0 P6 P! c) j7 l铁枪=8cb,5: m5 c/ Y7 H0 L7 V* v
钢剑=8cb,6- \+ j; b& H& Z0 L% x
战斧=8cb,7,
) i; s5 p1 w+ }# {8 o# {4 k7 f5 \% O

& L$ U, R7 P2 x% |8 W$ o5 p之后我们找到一个城,买木杖,30的,正好1e,100的铜剑64,0f是15,对应1500的ironclaw,37,对应550的,58对应880,一下最起码武器走完都可以验证.行了,该上班了.

签到天数: 1102 天

[LV.10]以坛为家III

发表于 2012-11-26 10:55:34 | 显示全部楼层
这图片看的不爽啊,楼主。

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-26 16:27:59 | 显示全部楼层
要是被百度给挡了,我也没办法,其他的,请提出应该在注明谢什么,反正我发的那个巧用变化次数找到吞食天地的控制隐藏物品是否被找到的文,以也是常常被挡。可恶的百度。http://bbs.emu618.com/forum.php? ... D328%26typeid%3D328

该用户从未签到

发表于 2012-11-26 18:24:38 | 显示全部楼层
论坛不是有附件功能吗
[发帖际遇]: 湘西小人物 发帖时在路边捡到 4 个 柠檬,偷偷放进了口袋. 幸运榜 / 衰神榜

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-26 19:11:16 | 显示全部楼层
欧,试试吧
! U7 \1 U7 X1 I9 h5 w- l3 xfile:///C:%5CUsers%5CADMINI%7E1%5CAppData%5CLocal%5CTemp%5Cmsohtml1%5C01%5Cclip_image002.jpg
  [! c6 T0 {1 n1 q/ Y( u/ \/ @3 ?; Cfile:///C:%5CUsers%5CADMINI%7E1%5CAppData%5CLocal%5CTemp%5Cmsohtml1%5C01%5Cclip_image004.jpg& W! Z; l% O1 {" n5 k  |
file:///C:%5CUsers%5CADMINI%7E1%5CAppData%5CLocal%5CTemp%5Cmsohtml1%5C01%5Cclip_image006.jpg
- s) z) G1 Z/ m$ f7 }# i6 a,看看成否,这是第一楼的三个图

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-26 19:14:03 | 显示全部楼层
在此请问斑竹,到底附件在哪里,我用这里的word的黏贴也变成。

该用户从未签到

发表于 2012-11-26 22:30:28 | 显示全部楼层
sdiencelee 发表于 2012-11-26 19:14
4 l# c: q0 b! t* J6 P6 \% s7 r在此请问斑竹,到底附件在哪里,我用这里的word的黏贴也变成。

6 C/ N' K8 p* X) C- S你查看下权限
" Z* ~" |; m6 G/ j3 N( R) f设置 用户组
[发帖际遇]: 湘西小人物 在论坛发帖时没有注意,被小偷偷去了 3 个 柠檬. 幸运榜 / 衰神榜

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-27 06:31:38 | 显示全部楼层
谢谢斑竹,在网上看到这里有许多hack的rom的教程或是帖子,也是刚学的一点点hack(不到两个月)
2 j7 _$ w3 i" Y# t; K# }所以,刚来、属于新人,权限低,没关系,我试试在其他的网页贴图吧。

点评

7500航班 http://www.6699.tv/kb/59740/ 罪恶之城2 http://www.6699.tv/dz/59718/  发表于 2013-2-20 18:42

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-27 08:54:46 | 显示全部楼层
本帖最后由 sdiencelee 于 2012-11-29 17:33 编辑 1 e( u) O! X( h5 y

6 l# e1 _* @9 O下面,我试试看看到底在后面加零的,成功与否,我也不知,开头说是实践,有错误就要如实写出来。若要暂时放弃此处也会写出来的。在原来我们可以基本确定a03几-a06几这段是在后面加零的,在vnes下,点击pc为??时暂停(执行断点,下同),点击执行后30条指令,之后发现30条不够,慢慢加到近100条,出现了$a065之后的$a067,就出现了18,01就是280的价格.而在a033之后,发现了a059的跳转.A046的跳转,没办法,直接看机器码或是6502的反编译器,暂时找不到6502反汇编器,没办法,先使用fceu的指令记录器(正好顺便教一下这个用法).如图,设置两个执行断点(原来不知道这样设置或是条件不允许如此设置,记录为文件时很大,除了editplus打开快点外,其他都很慢),这次用的120的wooden hat,这是记录出来的东西,我先自己研究研究.( V, t8 ~4 |2 }
FCEUX 2.1.6-interim svn2248 - 痕迹记录文件( _2 p1 d( Z9 ~2 l. G' y4 Q
$8BDE:BD E2 8D  LDA $8DE2,X @ $8E29 = #$0C A:47 X:47 Y:00 S:DC P:nvUBdIzc
6 Y. f, s# t) e* B  v$8BE1:29 7F     AND #$7F                   A:0C X:47 Y:00 S:DC P:nvUBdIzc
0 U. h6 e" Q9 J* T- I; y$8BE3:AE 0F 6E  LDX $6E0F = #$00           A:0C X:47 Y:00 S:DC P:nvUBdIzc
; e5 w2 u5 W1 N8 J1 ~$8BE6:20 35 A0  JSR $A035                  A:0C X:00 Y:00 S:DC P:nvUBdIZc
: n& Z9 h4 b- b+ r0 ^$A035:8D 11 6E  STA $6E11 = #$00           A:0C X:00 Y:00 S:DA P:nvUBdIZc
  O/ a6 l+ U, ~& L2 z5 N. N" j* i$A038:A9 00     LDA #$00                   A:0C X:00 Y:00 S:DA P:nvUBdIZc/ m: p3 ]% d; G. d
$A03A:8D 12 6E  STA $6E12 = #$78           A:00 X:00 Y:00 S:DA P:nvUBdIZc
! ~2 n2 Y8 D; e; V% @) v* f, Y' J$A03D:8D 13 6E  STA $6E13 = #$00           A:00 X:00 Y:00 S:DA P:nvUBdIZc
' m- q0 R0 H0 j" V$A040:8D 14 6E  STA $6E14 = #$00           A:00 X:00 Y:00 S:DA P:nvUBdIZc    //$6e11=a,$6e12-$5e14=0(初始化)
2 C; f% M; \( G- ^9 K0 O8 C$A043:4E 11 6E  LSR $6E11 = #$0C           A:00 X:00 Y:00 S:DA P:nvUBdIZc   //$6e11=$6e11/2+ ?3 D* t3 Q6 h- I* U
$A046:90 16     BCC $A05E                  A:00 X:00 Y:00 S:DA P:nvUBdIzc    //能除开则跳转16个地址即执行A05E,不行则继续执行A048
) }+ [7 U7 M+ {) z. t! D2 N$A05E:16 00     ASL $00,X @ $0000 = #$0A   A:00 X:00 Y:00 S:DA P:nvUBdIzc
5 \* ~6 x- @1 C# G" J$A060:36 01     ROL $01,X @ $0001 = #$00   A:00 X:00 Y:00 S:DA P:nvUBdIzc
* u9 H, o0 {4 O7 h  w4 W3 d; d. Q$A062:AD 11 6E  LDA $6E11 = #$06           A:00 X:00 Y:00 S:DA P:nvUBdIZc1 d8 s4 t# t5 G" t- n, y, N% ]
$A065:D0 DC     BNE $A043                  A:06 X:00 Y:00 S:DA P:nvUBdIzc  L' w2 h$ u9 G" ]7 b. v
$A043:4E 11 6E  LSR $6E11 = #$06           A:06 X:00 Y:00 S:DA P:nvUBdIzc7 s" q8 j/ ]9 f2 J+ y: U7 y5 J2 c
$A046:90 16     BCC $A05E                  A:06 X:00 Y:00 S:DA P:nvUBdIzc$ a" f% z. K6 I' y* O1 G
$A05E:16 00     ASL $00,X @ $0000 = #$14   A:06 X:00 Y:00 S:DA P:nvUBdIzc
$ S6 V0 `3 G! t2 w$A060:36 01     ROL $01,X @ $0001 = #$00   A:06 X:00 Y:00 S:DA P:nvUBdIzc
; J& s  w8 U! G$ g9 H8 u! @% G% h$A062:AD 11 6E  LDA $6E11 = #$03           A:06 X:00 Y:00 S:DA P:nvUBdIZc, o  _- N; W3 S- a/ d
$A065:D0 DC     BNE $A043                  A:03 X:00 Y:00 S:DA P:nvUBdIzc
$ O, I  q2 w( v+ m. G6 r2 |" ^$A043:4E 11 6E  LSR $6E11 = #$03           A:03 X:00 Y:00 S:DA P:nvUBdIzc2 o3 U: L8 y  i: _: |9 O7 i
$A046:90 16     BCC $A05E                  A:03 X:00 Y:00 S:DA P:nvUBdIzC
, U  _2 [# Q& k' O3 o0 Q$A048:B5 00     LDA $00,X @ $0000 = #$28   A:03 X:00 Y:00 S:DA P:nvUBdIzC
3 R7 w' ]  V3 z$A04A:18        CLC                        A:28 X:00 Y:00 S:DA P:nvUBdIzC; Q9 M/ d- ]- s- d6 F& W' q5 y# z
$A04B:6D 12 6E  ADC $6E12 = #$00           A:28 X:00 Y:00 S:DA P:nvUBdIzc2 B4 K4 O% ^4 j' ^+ Z) k+ D% T
$A04E:8D 12 6E  STA $6E12 = #$00           A:28 X:00 Y:00 S:DA P:nvUBdIzc
2 U1 t( L: Q- }. |' _4 J$A051:B5 01     LDA $01,X @ $0001 = #$00   A:28 X:00 Y:00 S:DA P:nvUBdIzc5 d4 r1 U8 V. n* h; x: s
$A053:6D 13 6E  ADC $6E13 = #$00           A:00 X:00 Y:00 S:DA P:nvUBdIZc0 u. M4 }9 R1 R. R0 O
$A056:8D 13 6E  STA $6E13 = #$00           A:00 X:00 Y:00 S:DA P:nvUBdIZc
3 r9 D2 A8 e1 y, q8 {! F  s$A059:90 03     BCC $A05E                  A:00 X:00 Y:00 S:DA P:nvUBdIZc
8 @" @. _0 f' p" l$A05E:16 00     ASL $00,X @ $0000 = #$28   A:00 X:00 Y:00 S:DA P:nvUBdIZc
5 c, G  T* G" Y) v$A060:36 01     ROL $01,X @ $0001 = #$00   A:00 X:00 Y:00 S:DA P:nvUBdIzc5 H  Q/ ?2 a9 P% J  m6 p: k
$A062:AD 11 6E  LDA $6E11 = #$01           A:00 X:00 Y:00 S:DA P:nvUBdIZc, d8 E- j! m6 ^: d  u/ R
$A065:D0 DC     BNE $A043                  A:01 X:00 Y:00 S:DA P:nvUBdIzc
( A( l0 G/ \  S! u* X& m/ u$A043:4E 11 6E  LSR $6E11 = #$01           A:01 X:00 Y:00 S:DA P:nvUBdIzc
" V- r3 Y  I: J$A046:90 16     BCC $A05E                  A:01 X:00 Y:00 S:DA P:nvUBdIZC7 l  p9 C. l) X' g9 `& l& S
$A048:B5 00     LDA $00,X @ $0000 = #$50   A:01 X:00 Y:00 S:DA P:nvUBdIZC9 E" l2 r. K/ p6 v. G: D
$A04A:18        CLC                        A:50 X:00 Y:00 S:DA P:nvUBdIzC; q6 I& \: w+ f" O' Z
$A04B:6D 12 6E  ADC $6E12 = #$28           A:50 X:00 Y:00 S:DA P:nvUBdIzc
! x! b8 C3 ]- w3 m% W! E4 N$A04E:8D 12 6E  STA $6E12 = #$28           A:78 X:00 Y:00 S:DA P:nvUBdIzc4 o/ t$ w6 _& p% J1 C! d
$A051:B5 01     LDA $01,X @ $0001 = #$00   A:78 X:00 Y:00 S:DA P:nvUBdIzc$ u: \& D# C9 N$ m
$A053:6D 13 6E  ADC $6E13 = #$00           A:00 X:00 Y:00 S:DA P:nvUBdIZc
- W1 F4 v0 G8 N5 C% d$A056:8D 13 6E  STA $6E13 = #$00           A:00 X:00 Y:00 S:DA P:nvUBdIZc
, K, O2 w. I* d: Y3 ^$A059:90 03     BCC $A05E                  A:00 X:00 Y:00 S:DA P:nvUBdIZc
: J( U0 X7 S: ]$ N$A05E:16 00     ASL $00,X @ $0000 = #$50   A:00 X:00 Y:00 S:DA P:nvUBdIZc
6 v) u, b( `6 d, e6 k( s- M$A060:36 01     ROL $01,X @ $0001 = #$00   A:00 X:00 Y:00 S:DA P:NvUBdIzc0 |) p4 g6 D6 @. @# l* y
$A062:AD 11 6E  LDA $6E11 = #$00           A:00 X:00 Y:00 S:DA P:nvUBdIZc
; K+ ^8 U- }* ]+ {$A065:D0 DC     BNE $A043                  A:00 X:00 Y:00 S:DA P:nvUBdIZc1 ~0 q) M" }  g# h9 t; _
其实呢,这段机器码很短($A035-$A065),即使对于菜鸟我来说,慢慢来可以一步步写出。即使没有6502的反汇编器(到必要时,才知道某些软件是干什么的,比如这个6502的反汇编器)无非就是慢慢查一下汇编指令的机器码.先慢慢读这段码吧
& h" z9 M9 Q' s7 N: M- u6 r& M【转到了我的qq空间发一下看看如何】! k+ Y. F2 G* L5 @& q
下面我试图解释一下,是菜鸟,出错了有相当大可能。
8 O" n8 |6 u6 L; y) i7 _, w4 |- ?( G3 _  `9 N/ m2 o8 f
A043-A046:$6e11=$6e11/2,能除开则跳转16个地址即执行A05E,不行则继续3 L& p( T! R  \2 n; F1 B
* G5 Q% c# D) e+ K" g
A048,将$00的值(哪里来的?),赋给寄存器a, m0 c+ X4 G) \- f4 P
A04A -A056 清位
9 r" ?. U/ y6 k4 |& z9 M( b: x- X6 k

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-27 16:05:44 | 显示全部楼层
本帖最后由 sdiencelee 于 2012-11-28 20:44 编辑
; t. `) ]" G% h/ |& b2 j9 _8 }) C! w3 A$ ]7 p, i  |" q- d
我要气死了,qq也在搞这些,都是我自己截出来的图呀。
* l5 w( W- O+ }  G5 o不喜欢在发帖(上新楼),直接编辑,这也可以保证以后一楼专门一个主题(入经验,怪物)这回先试验一下改改卖出价格,用15000的dragonkiller卖出,慢慢的搜索到断点,将B36b,和B4B8设置两个执行断点(已经看出B36b之前耳朵值为原价,后面的以后为卖出价经过折旧率后),得到一些代码,其中最重要的后面几句! `2 ]6 j" h+ ~& i. C, u
…………
' Z" C: X& ]; ]6 X) q' T$B4A5:A5 00     LDA $0000 = #$B4           A:00 X:00 Y:00 S:DE P:nvUBdIZC
7 ^9 k- G$ m$ J4 t' M( J$B4A7:38        SEC                        A:B4 X:00 Y:00 S:DE P:NvUBdIzC
' x% I2 p9 e9 ]/ i$B4A8:E5 03     SBC $0003 = #$2D           A:B4 X:00 Y:00 S:DE P:NvUBdIzC& v. T" ]* N' X
$B4AA:85 00     STA $0000 = #$B4           A:87 X:00 Y:00 S:DE P:NvUBdIzC
# l3 u) y6 `8 U+ e* t$B4AC:A5 01     LDA $0001 = #$00           A:87 X:00 Y:00 S:DE P:NvUBdIzC; o- ^8 }5 c6 e* P3 G) m: E
$B4AE:E5 04     SBC $0004 = #$00           A:00 X:00 Y:00 S:DE P:nvUBdIZC8 I; C" O( k4 R" S7 P$ K/ x
$B4B0:85 01     STA $0001 = #$00           A:00 X:00 Y:00 S:DE P:nvUBdIZC
) o0 |4 A8 z# M' }$B4B2:A5 02     LDA $0002 = #$00           A:00 X:00 Y:00 S:DE P:nvUBdIZC
8 J) c# V" A  a2 d& l+ p6 h$B4B4:E5 05     SBC $0005 = #$00           A:00 X:00 Y:00 S:DE P:nvUBdIZC  S" G! f4 @8 V  q# Z" h$ ^$ e
$B4B6:85 02     STA $0002 = #$00           A:00 X:00 Y:00 S:DE P:nvUBdIZC" a3 j/ l' a1 P  j0 k" _) I# g  u
买了180(b4)的铠甲,应该是卖价是135(B4-2d),改成了B4+2d,就可以了(因为直接改成sbc #$00会有些出错的可能,上次在百度的勇者斗恶龙说到一个1战一千经验的,方法是,7203每次战斗所得到的经验,具体是被打死一个敌人,加上个敌人的经验值再付给7203,结果我想,竟然这可以这样,直接在没打死一个敌人设置断点设成1000的经验,反正打死一个敌人,就直接$7203=#1000,也没事的,结果挂机),将对应位置sec(减法准备)改成clc(加法准备) 38>18,后面的3个E5>65(sbc改为adc).哈哈,还行.现在看出来标志位 P寄存器,字母大写为该字母1,小写为0./ v7 g2 L: Z/ m' s5 w$ w  U: W
以后就是买入四,卖出5,而且人家主动卖的,我可没有逼他,黑社会高利贷就是如此炼成的。{:4_104:} ,反正稍微侧测了下,没事,

签到天数: 125 天

[LV.7]常住居民III

发表于 2012-11-27 19:33:59 | 显示全部楼层
{:4_97:}加油!!
[发帖际遇]: zeng_k 在论坛发帖时没有注意,被小偷偷去了 5 个 柠檬. 幸运榜 / 衰神榜

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-30 14:27:59 | 显示全部楼层
现在总结一些技巧搜索技巧,本人还没有自己写代码,毕竟是菜鸟,只是针对追踪过程自己的心得写一下。更像是技巧,而不是技术的过硬。1 z( o- U5 c  c$ H; w
1.当然是存档位置要尽可能的与想要追踪的东西,接近,这样可以减少不必要的过程,提高追踪效率。
5 F9 U( v; t# |+ K  l& ~  a9 B2.在限制数值为多少时,会使用vnes,而非fceu,因为看到fceu的后面注释语句都加个@,说明在at什么条件下的,而我们所做都是需要语句执行后的状态,所以往往会使用vnes 用最常用的方式[????]=a=0x??(有时候需要将a去掉,写成[????] =0x??,而选择突破口则往往使用1个字节以上的,因为方便上下查看另外一位的(前或是后一位),以便马上判断是否被误追踪.并且,往往再次追踪选择后一位即高一位进行追踪,因为我碰到的都是,很多的地址追踪过程中全是使用一个固定地址,挪后一位也可以提高效率.
' j, z( [5 q/ r( `9 O* A/ q3.选择突破口是,往往要数值比较大的,因为追踪基本都是直接追进零页地址这个变化频率超快的地方,往往就可以出现断点的非预想型跳出,即使在限制条件为某地址为某数时(由于数较小,所以要限制数要大)
1 a0 u  x6 Q- v( a6 D& j4.可以用执行断点时最好使用执行断点.% V# y9 Z( b# i& z4 |
以上是我在搜索过程中的心得,可能是老在hack数据量大的rpg游戏,所以,往往时常要调用常用公式,如加减法,所以才会追踪过程中常会将数据传输到零页地址用特定的子程序进行操作.* \1 n8 p2 Z# A; L
就是这些所总结,毕竟本人是菜鸟的.以后有了慢慢在此楼继续写

签到天数: 31 天

[LV.5]常住居民I

 楼主| 发表于 2012-11-30 10:49:58 | 显示全部楼层
由于消耗的Mp值,很小,过程中常会出现非预定性地址出现,而且跳出频率,往往很快,无暇按a键,所以,必要时使用了手柄状态
+ V+ D9 }4 W  \8 Q2 S# m; Q& I: F7 ?) y4 s  `3 Y8 r, Z. s
地址$14锁定为1的方法,起到强制按a键的作用(具体如何快速的找到这个地址可以参见????的第几楼),为此选择消耗mp最多healusall& ^0 e0 I# c+ P( ~# I, W- m

  E- P7 G. ^; [0 _  J7 @2 k作为突破口.8 i! f& _" s3 `% B0 n6 `+ q
安排公主alena和勇者(以便速度快的公主先出手后,勇者再出手,抓住时机此时存档),,打仗后存档,[6004]为断点,来自$76,接着写入
5 D# F7 [# k, f( o3 X& f
& V* \! _+ |! X6 P0 {, ?$ f6 U[0076]=a=0x24继续,出现了(821e:$6f>),在此则有(8152:$78>),(810d(由c3A6转0023再转):$20>),(a2f5:pla),无奈只能再试一个其
& B) Y- p2 y; c1 l% Y  s1 |
+ m5 |% T% T' r! x* ?$ Q. [% X& I+ l/ Q他消耗MP的魔法,来去掉一些.断点写[006f]=a=0xc,发现果然如预料的由于数小,断点非要求跳出,只能将0014锁定为1.排除了8152.由
" J( K! c" Q7 Q, Z2 T# \9 {6 `
/ _1 M$ V3 b, N/ M2 Y& A于A2f5的pla暂时找不到在哪,先以此为准,若是对(810d:$20>)改对了,就无需了.再次,则,用healusall,写入[0020]=a=0x24,这回没有, F0 ^6 D# w- @/ v1 @% H

7 m7 I5 g& N5 w到战斗状态就停了,对了可能是在判断主角的mp值够不够用,为什么我没有想到呢?记住[0020]=a=0x24这个断点,将其消耗到比较小,直( I9 O2 G+ C; h2 Q: |
% g. B6 f$ L- L) O! I/ T
接金手指写入6004赋值1,将公主退下,只是主角一人在马车外,在光标停在healusall的地方,存档,(c3aa(由B92b转来):$BA4E,X>),
: y8 o6 o' I: P5 ~: D' j& \: k6 s' t  w# E# \
(C40D:$02>),(c38d:$20>)[因为又回到了$20,排除],再次使用vivify,看看能否排除(A3aa:6E10 abd #$1f>),(c40d:$02>),先追
" D. X5 F8 Z" s3 s% u5 d: \/ c4 C) b( v3 @3 ~. n
$BA4E,记录执行读那点C92B(以便用fceu),注意x=19,找到BA67,改为1,之后消耗为Mp0后,不能使用,证明改内存成功,试试改rom,用
( J+ Z; n1 g, C# f7 I. h
3 J5 q& S# P8 wfceu,消耗MP到小于36,发现很难停住,直接ue将2个东西替换,成功只消耗一个mp,healusall。如此,没完,因为是菜鸟,先要整理一下思路。未完,待完善!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|国治模拟精品屋 ( 沪ICP备15012945号-1 )

GMT+8, 2026-2-25 18:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表