▲▲用WPE制作外挂实例    (转) (申请点亮)

社区服务
高级搜索
猴岛论坛DNF地下城与勇士▲▲用WPE制作外挂实例    (转) (申请点亮)
发帖 回复
倒序阅读 最近浏览的帖子最近浏览的版块
10个回复

▲▲用WPE制作外挂实例    (转) (申请点亮)

楼层直达
xujunyi

ZxID:3822259

等级: 列兵
举报 只看楼主 使用道具 楼主   发表于: 2009-03-13 0
▲▲用WPE制作外挂实例
WPE实际经验和实例
1.虎卫版的破解 2.WPE系列教程之封包用法篇
3.WPE系列教程之刷钱封包制作资料篇  4.WPE系列教程之祝福油和幽灵手套篇
5.WPE系列教程之神秘封包制作篇 6.WPE系列教程之攻击代码篇

虽然好多外挂都被封了,可是现在回头看看,对我们的学习使用wpe还是有很大的帮助,以下的几篇文章都是实际的经验,而且里面的方法更是值得我们学习,如何分析问题,如何查找关键数据,从何处入手,等等。这些文章都是从网站上抄来的,首先向他们的作者致歉,因为经过好多次的转载,有些作者都找不到了,因此没有署名。下面让我们一起来看看:
虎卫版的破解
虎卫版更新了mir.dat文件,在我们进入游戏时会有一个验证身份的过程,类似答考卷。举个例子:服务器给mir.dat文件的试卷题目是“天王盖地虎”然后虎卫的mir.dat答案是“宝塔镇蛇妖”,这样,服务器就知道了mir.dat是合法的。而半月看血的那个mir.dat文件并不知道正确的答案是什么,只有硬着头皮随便说了个答案。所以它的身份很快就被揭穿了。最终的结果就是,我们被服务器踢出来了!
    现在,我们需要做的就是----欺骗服务器,让它认为半月看血的mir.dat文件是合法的。我们知道,软件WPE的主要功能之一就是更换发送给服务器的数据包。只要在服务器没有收到半月看血的mir.dat文件提交的答案之前,利用WPE将答案修改成正确的,服务器就会认为半月看血的mir.dat文件是合法的。这样,挥半月,全屏看血,一步起跑,超负重等功能就又可以实现了。
    下面就是具体的做法。(所需工具:WPE)
    准备工作:将patch这个文件改个名,这样可以避免服务器将半月版的mir.dat文件自动更新成虎卫版的(两个版本的mir.dat文件大小不一样),这样做的话进入游戏的时候会提示patch.exe程序不能使用,别管他,点OK就可以了。
    最关键的一步,是要知道合法的mir.dat文件所提交的试卷中的正确答案。在每次进入游戏前,我们需要做的是选择自己的游戏帐号在哪个服务器、选择人物等等。这里的每次选择,都会向服务器发送相应的封包。虎卫版和半月版在进入游戏之前所进行的前几个步骤并没有太大的区别。在最后选择人物,点“开始”以后就有区别了----使用半月看血的会被服务器踢出来。所以,我们可以初步认定,正是这一步在提交试卷。所以我们可以使用不同的mir.dat进入游戏,在点开始之前用WPE截一下数据就可以知道正确的答案和错误的答案都是什么了。
    注意:在使用WPE之前最好先对这个软件进行一下设置,让它只截取我们发送给服务器的封包。这样的封包才是我们能够随意修改的。下面是我截取的数据
使用半月mir.dat
SEND-> 0000 23 35 3C 3C 3C 3C 3C 42 58 3C 3C 3C 3C 3C 3C 3C #5<<<<<BX<<<<<<<
SEND-> 0010 3C 3C 56 62 61 5D 57 63 5D 65 57 5F 3C 6C 49 6E <<Vba]Wc]eW_<lIn
SEND-> 0020 7B 47 7A 58 47 5A 6C 78 53 52 67 68 63 5B 21 {GzXGZlxSRghc[!
SEND-> 0000 23 36 46 5E 65 66 56 52 41 6A 5A 42 61 6A 48 3F #6F^efVRAjZBajH?
SEND-> 0010 3C 73 47 78 6B 75 6C 69 77 3F 6D 59 56 6A 6E 59 <sGxkuliw?mYVjnY
SEND-> 0020 78 6B 48 4F 4C 70 4A 3F 58 70 47 6F 44 6C 48 3F xkHOLpJ?XpGoDlH?
SEND-> 0030 40 6D 48 3F 3C 72 47 6F 3C 21 @mH?<rGo<!
SEND-> 0000 23 37 3C 3C 3C 3C 3C 4B 64 3F 3C 3C 3C 3C 3C 3C #7<<<<<Kd?<<<<<<
SEND-> 0010 3C 3C 21 <<!
SEND-> 0000 2A *
SEND-> 0000 23 38 3C 3C 3C 3C 3C 41 40 3C 3C 3C 3C 3C 3C 3C #8<<<<<A@<<<<<<<
SEND-> 0010 3C 3C 21 <<!
使用虎卫mir.dat
SEND-> 0000 23 34 3C 3C 3C 3C 3C 42 58 3C 3C 3C 3C 3C 3C 3C #4<<<<<BX<<<<<<<
SEND-> 0010 3C 3C 56 62 61 5D 57 63 5D 65 57 5F 3C 6C 49 6E <<Vba]Wc]eW_<lIn
SEND-> 0020 7B 47 7A 58 47 5A 6C 78 53 52 67 68 63 5B 21 {GzXGZlxSRghc[!
SEND-> 0000 23 35 46 5E 65 66 56 52 41 6A 5A 42 61 6A 48 3F #5F^efVRAjZBajH?
SEND-> 0010 3C 73 47 78 6B 75 6C 69 77 3F 6D 59 56 6A 6E 59 <sGxkuliw?mYVjnY
SEND-> 0020 78 6B 48 4F 4C 73 48 4F 40 6F 47 6F 44 6C 48 3F xkHOLsHO@oGoDlH?
SEND-> 0030 44 6C 49 4F 44 6E 47 6F 3C 21 DlIODnGo<!
SEND-> 0000 23 36 3C 3C 3C 3C 3C 4B 64 3F 3C 3C 3C 3C 3C 3C #6<<<<<Kd?<<<<<<
SEND-> 0010 3C 3C 21 <<!
SEND-> 0000 2A *
SEND-> 0000 23 37 3C 3C 3C 3C 3C 41 40 3C 3C 3C 3C 3C 3C 3C #7<<<<<A@<<<<<<<
SEND-> 0010 3C 3C 21 <<!
SEND-> 0000 2A *
SEND-> 0000 2A *
    可以看到,半月版截到了5组封包,虎卫版是7组。在这里我们大可不必理会数据的多少,对比的时候以半月版为准。虎卫版数据多的原因是因为我们已经正常进入游戏了。多出来的数据可能是客户端告诉服务器自己已经正常进入了,这样服务器才会告诉客户端,他有什么物品,等级是多少……
    没得到我是神的指点前,我前半夜的时间就是浪费在这里了。
    再观察这些数据可以看到,每组数据大多以23开头,紧跟在后面的是3x(x代表0-9的数字),这些是数据包编号信息,可以不理会它。右边是这些16进制数据对应的符号,我们对比右边的符号就能知道两个版本同一组包里面的信息有什么不同了。可以发现,两个版本所发送的第二组包差别最大。所以,这组数据成了重点!
    那天,我利用WPE的滤镜功能,(教程里有滤镜的使用说明),把半月版的除了数据编号以外的所有信息写到了滤镜的正确值里,又把虎卫的信息写到了伪造值中,运行滤镜。满以为这次会成功,结果服务器照踢不误。在这里我又浪费掉了后半夜时间~~~~~~
    后来得到我是神的指点,才知道即使是用同一个ID,使用同一个版本的mir.dat文件登陆,所得到的第二组数据也会有所不同,个人认为那些不同的数据可能和登陆的时间,服务器的状态有关。知道了这些,就可以把随机变化的不同部分排除掉。然后再对比两个版本截到的数据中其他部分,发现只有SEND-> 0030这一行的第1-6个数值是不一样的。把半月版的这6个数值填到滤镜中的正确值里,再把虎卫版相同位置上的6个数值填到伪造值里就可以欺骗服务器了。
    在使用滤镜的时候应该用它的“递进模式”,并且选上“自定位修改”,(这样设置后,WPE只要发现连续的这6个正确数值,就会连续的把这6个数值替换成为伪造值)滤镜的“查找长度最大值”(我理解成在多长的一组包里查找相关数据)默认是40,可是我们知道我们要修改的那组数值所在的封包长度已经超过40个字节了,所以我们可以将“查找长度最大值”设置成大于封包长度的值。(我是神设的是80,我自己设的是64)另外,当我们选上“递进模式”并且选上“自定位修改”后,伪造值的范围变成了-124到+124,应该从000处开始填入伪造值才能使滤镜真正生效。
    好了,运行滤镜吧,试着使用半月版进入传奇,结果是----成功。到了这一步,我高兴的不得了,终于成功了!
    可是好景不长,休息了几个小时后这个滤镜竟然失效了。重新按前面的方法截获数据,发现和以前截获的数据不一样了。我倒,原来服务器考试还分A、B卷啊。于是照改不误,多做了两个滤镜----这回彻底把服务器摆平了。(做成能够脱离WPE单独运行的封包后就可以给朋友用了)
    由于要将patch解决掉才能使用这个封包,没了自动更新的功能,换成其他区的用户登陆就会出现ID不存在的错误提示。好多朋友发表了解决这个问题的方法,有手工修改mir.ini文件的、有用WIN2000做模拟FTP服务器的、还有用防火墙截住patch不让它自动更新的。个人认为在网吧使用以上方法还是有点费事。
    我是在家里上网的,那个patch文件改名后进入游戏会出现“patch.exe程序不能使用”的提示,每次都要点“OK”,太罗嗦了。我把半月版的mir.dat设成只读属*了,所以那个patch就没法把它更新成虎卫版了。不过,换其它区的ID登陆还是有问题。大家想想办法把这个问题彻底解决。
WPE系列教程之封包用法篇
    由于不同区不同服务器的的数据不同,一个封包要想在每个服务器都能使用是不可能的。这就需要我们对原有的封包进行修改。
    大家不必要一味的要这个封包,要那个封包,学会了修改封包,就能自己动手了. 大家在发封包之前,都会和NPC说话,然后进行搜寻,得到一批数据,就是16进制代码我们要做的是打开所要发送的封包,然后选择要发送的命令如:Packet n 1,发送。现在一个封包命令就发出去了,这就是WPE的用法,我要说的是怎么修改,大家继续看:
    现在,我们双击左边的Packet n 1,会出来一条对话框,里面也有16进制代码我所需要做的是把第一排第3。4。5。6。4组数据修改成你刚才搜索的相应数据(注意:他的相应数据是在搜索的时候,左边带S符号的那几排数据)
    如果在搜索的时候,出现了许多带S符号的数据排,则证明,有地方出错,你退出传奇再进或者再次搜索一遍,一般只会出现2-3排的S,而其他带R的不用管他。你现在已经把其他服务器的封包改成你这个服务器能用的封包了。
比如赌场封包,在1号房搜索并修改1号封包数据后发送,撒6到了7号房,再搜索并修改2号封包数据后发送,依次类推就可以到40号房间。注意,修改9号封包也就是拿钱封包的时候必须等你出来与NPC对话出现成功字样的时候才能修改,如果你拿不到钱,你所修改的封包则无任何用处,所以要修改拿钱封包,必须你先得拿到一次钱,但是如果成功了和NPC说话后立即开始修改,而且要一次成功,慢点都无所谓,想想修改步骤,否则你失败了再点NPC就会送你回去。
    那么,现在虽然赌场的封了,你们还可以去试试神秘商店或者未知暗殿的封包,一样能改好了。

WPE系列教程之刷钱封包制作资料篇

第一位23 表示 # 是 开头
第二位 是数据传递的id从0-9(ascii码)
第三四位是你放在物品篮的数据
后面不变的则为此物品的数据

请大家自己研究!

WPE系列教程之祝福油和幽灵手套篇

  现在让你站在比奇的人给新人2捆随机(随机带多少,随便,看你自己了),4000gold
现在开始长征,我随机.......(此处省略若干过程),进比奇找老兵,给他4000到盟重!
在跑!跑到仓库旁边的客栈里面!找到林小姐......,切出传奇,现在使用封包

    打开wpe如果大家有找不到我说明里面点击的地方在那里的!请下载此版本对照.

    双击 SELECT 选择 mir.dat(现在你的传奇应该是打开的哦,别告诉我你关了)

    双击 trace 选择 开始,就是哪个箭头标志

    切回传奇 点林小姐

    切出传奇,停止截取,就是哪个方的按纽

    现在开始用脑袋,你应该可以看到你刚才打开wpe哪一大片空白的地方有数据了吧! 看看数据最前面,看到以S或者以R开头的小按纽了吗?现在找到以S开头的这样一段数据
xx xx yy yy yy yy oo xx xx xx xx xx xx xx xx xx
xx xx xx
ok,现在继续

    双击你看到的任意一个S或者R的小按纽,你会看到跳一个窗口出来,里面写了个数字,这个数字不固定,但是一般是 44 或者 56

    双击 SEND PACKET,看到<<封包列出>>下面的哪本打开的小书没有?,对了,点他选择祝福油AND幽灵手套封包,然后点<>右边的哪个垃圾箱

    双击 <<封包列出>> 下面的 packet n 1
    又开始用脑袋,你应该可以看到如下数据
xx xx zz zz zz zz oo xx xx xx xx xx xx xx xx xx
xx xx xx xx xx xx xx xx xx xx xx xx xx

现在继续

    把 zz zz zz zz 用yy yy yy yy替换掉!看清楚!为什么要替换掉!因为每个服务器的林小姐的代码是不一样的

    写完了点离开就可以可!现在把 packet n 1 点一下!你会发现 packet n 1 变蓝色了哦!对了,现在点哪个有3层的,有立体感的,画了个向右指的尖头的按纽,你会看到 <>,变成了1%,而且右边也有了个 packet n 1 ,ok,.你已经接近成功了!

    如果你用的我告诉你的哪个wpe版本的话,你可以看到在 <<开启插座我>> 右边有个数字,如果没有的话就不对!如果没有,重复第6 步.

    点击 阜 右边的那个 画了个黑色箭头的按纽,开始发送!现在切换回传奇,你就会看到一个对话框了!选择3,就是幽灵手套了!

    注意!在你没有退出整个传奇的情况下!你新人一走到!只需要执行第13步就可以了

    我们7个人!一个盟重,一个比奇,剩下的5个都在跑新人.............. 好累!如果还有人不会用的话!我就没有话说了

WPE系列教程之神秘封包制作篇

大家先到这里看看 (既然有现成的东西,何乐而不为,CC )

    再来说说我们现在玩的传奇。我这里就举个神秘商店的例子说明吧。

    1,进入传奇跑到兽人2F刘老头那
    2,打开WPE点选SELECT GAME双击MIR.DAT
    3,点选WPE上的TRACE按钮(此时出现一个3角的播放键和4方的停止键)点播放键开始截取数据
    4,立刻切换回传奇点击刘老头,出现对话框(刘老头对你说XXX很厉害的字样)后切换回WPE点4方型的停止键。

    这样我们就截取一组S和R数据(发给服务器点击刘老头和从服务器接收到的数据)
排除掉接收数据我们就会看到一组发送数据类下
23 3? ?? ?? ?? ?? 3F 4B 48 3F 3C 3C 3C 3C 3C 3C 3C 3C 21
(具体多少自己看了,都那个样)

    接着我们点选SEND PACKET按钮。打开(下载或者别人提供)进神秘的封包。查看刘老头的数据,抄下或者用截图程序截下。关闭SEND PACKET窗口。回到WPE主窗口点选FILTER按钮,(这里用NORMAL模式即可)把你自己截取到的刘老头的数据填入第一行然后开始对比自己截取的数据与封包内的数据的差别。。。找到不同的数据就填入第2行相同位置。

比如: 位置 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
原 数据 23 3? ?? ?? ?? ?? 3F 4B [48] 3F 3C 3C 3C 3C 3C 3C 3C 3C [21]
修改数据 23 3? ?? ?? ?? ?? 3F 4B [44] 3F 3C 3C 3C 3C 3C 3C 3C 3C [4C] ?? ?? ??

    这样你只需在第2行的第9位置填入44和19位置填入4C即可,如果修改数据长度超过原数据, 就把他当做不同数据在19位置后继续填入。但是在右边的封包长度框内必须自定义封包长度,不然FILTER只过滤1-19位置的数据。封包长度要看你修改数据的长度了,大与修改数据长度也可以。

    如何实现全区通用---在传奇版本相同的情况下,各区封包是相同的。不同的只是位置代码而已,大家看一下上面的2排数据,第一位 23 是开始代码,第 2位是 31-39的数字,是数据编号,3-6位就是位置代码。在FILTER中把原数据行的3-6位清空不进行过滤,就能简单的实现全区通用。

    再检查一次看看有没有错误,如果可以的话按QUIT推出FILTER编辑框。回到FILTER控制窗口,勾上刚才修改的FILTER,启动FILTER(从左到右第5个按钮)进入传奇,点刘老头,如果正常的话刘老头会拿走你5000块钱跟你说起废话

    回到WPE的FILTER控制框保存刚才修改的FILTER为FLT文件

WPE系列教程之攻击代码篇

特殊修理:点普通修理,有时候(特别第一次点击)会出不来什么什么“正好有材料,价格是3倍什么什么的废话,你需要点返回再点修理到一直出来为止,基本上第2次就可以了。

    传奇出错:(个人想法)主要是封包长度问题。进行封包过滤的时候由于过滤封包长度要大于待过滤封包。导致传奇非法。出错。目前还没解决,希望高手们能多发发帖子。。。

    攻击方式:战士在传奇里攻击方式有空放3种(按住SHIFT打空),打怪4种(基本,攻杀,刺杀,烈火),攻击方向有8个,代码3C,3D,3E,3F,41,42等。攻杀代码是64,刺杀是68,放出攻杀和刺杀是由客户机随即决定的。刺杀是有条件的(也是客户机根据条件决定的)。所以只要对截取到的封包过滤攻击方式那一字节就可以放出。
进入游戏,购买红A一个,得包如下:
SEND-> 0000 AA 55 09 00 85 11 00 01 00 1C 00 01 00 55 AA
购买红B一个,得包如下:
SEND-> 0000 AA 55 09 00 85 11 00 01 00 1D 00 01 00 55 AA

比较一下,我们就知道第10字节发生了变化,初步可以判断10号字节是控制物品代码的,以后分析多了我们就知道字节10~11是共同控制物品代码的,也就是说决战里物品代码是2个字节来控制的。

购买红A10个,得包如下:
SEND-> 0000 AA 55 09 00 85 11 00 01 00 1C 00 0A 00 55 AA

和买一个红A得到的包比较一下,我们就知道第12字节是控制物品数量的,如果买的多了,就知道13字节和12字节两个字节是控制物品数量的。

通过比较,我们已经知道这个15字节长度的包里面4个字节的作用了,我们继续分析其他字节的作用。

同时购买红A和红B各一个,得包如下:
SEND-> 0000 AA 55 0D 00 85 11 00 01 00 1C 00 01 00 1D 00 01
SEND-> 0010 00 55 AA

同时购买红A红B饼干A各一个,(饼干代码22 00)得包如下:
SEND-> 0000 AA 55 11 00 85 11 00 03 00 1C 00 01 00 1D 00 01
SEND-> 0010 00 22 00 01 00 55 AA

通过和购买一个红A的包进行比较,我们发现决战里一次购买多个不同的包实际就是增加了物品代码和数量代码,所以上面的包长度发生了变化。多一个品种就多4个字节(因为物品代码2个字节,数量代码2个字节)。我们发现每个包开始和结束都是AA 55和55 AA,可以判断是这个包的起始和终止控制字节,没有什么作用,只是让服务器知道这个包。那么我们看第3个字节,购买一种物品的时候是09,购买两种物品是0D,购买三种的时候就是11了,每次增加了4个字节,仔细看一下单独购买红A的包,我们发现除去每个包开始的AA 55和结束时的55 AA,除去第3个字节本身,还有10个字节,但是后面第3个字节后面是00,如果3,和4字节就是控制发送字节长度的话,那么我们就可以解释上面3个包第3个字节的变化了(09 00-0D 00-11 00)。也就是说3和4字节是表示后面要发送字节的数量的。大家可以自己数一下,第4个字节后,上面3个包里有用的数据只有9个字节,11个字节和17个字节。

我们刚才都是买,现在我们卖一个物品看看。卖红A一个,得包如下:
SEND-> 0000 AA 55 09 00 88 11 00 01 00 1C 00 01 00 55 AA

和单独购买一个红A的包比较,我们发现第5字节发生了变化,那么我们就可以知道第5字节是控制游戏动作的,在这个例子里,这个字节起着判定你买还是卖。如果分析多了,我们也还就可以知道第6字节和第5字节是共同作用的。我分析的没那么多,所以还不知道第7字节是不是也和前面的5,6字节共同作用的,不过可以暂时假定是和第5,6字节共同控制人物执行某种操作或者动作的代码。

通过这样的方法,我们就知道了决战这个游戏中一种类型包的数据结构,前几天刷蓝药等等其实就是用蓝药的代码替换了红A的代码,这样,我们就可以从NPC那里直接买到很多不可买到的物品(当然现在不可以了,程序改过了,呵呵)。如果想深入分析这个游戏的数据结构,找到弱点,只抓发送的封包是不够的,一定要抓服务器返给你的包,只有通过比较分析,我们才能全面掌握一个游戏的数据结构。当然不同的游戏分析方法是不一样的,决战的数据结构很简单,比较好分析,做例子是在好不过的了。

[ 此贴被xujunyi在2009-03-13 19:49重新编辑 ]
qq383843874

ZxID:2965194

等级: 准尉
你长的丑不是你的错,但是你出来吓人就是你的错了。。。。。。
举报 只看该作者 沙发   发表于: 2009-03-13 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
SFaaa  a a
攻击就是防御

ZxID:1697024

等级: 上尉
举报 只看该作者 板凳   发表于: 2009-03-13 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
眼睛都花了。。。!
xujunyi

ZxID:3822259

等级: 列兵
举报 只看该作者 地板   发表于: 2009-03-13 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
    虽然是转来的    但是看看不错  希望对小猴子有用
itxiu826

ZxID:2523317

等级: 大校
山、稳重的山、随着时间变化的东西;

举报 只看该作者 4楼  发表于: 2009-03-13 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
不是很懂都没看完。主要是刷刀谢谢。
5夜丶狠凄美

ZxID:4441989

等级: 上尉
奈何桥上等你`

举报 只看该作者 5楼  发表于: 2009-03-14 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
       
本帖de评分: 1 条评分 DB -1
DB-1

恶意灌水

2364933

ZxID:4091467

等级: 下士
哄女人像挂Q一样,每天至少两小时,达到一定天数就可以太阳了.
举报 只看该作者 6楼  发表于: 2009-03-14 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
好难懂啊
别和我谈理想,戒了!
ー乐ハ拉面

ZxID:1693421

等级: 元老
随缘、顺其自然!

举报 只看该作者 7楼  发表于: 2009-03-14 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
转来的帖子,我一秒看完``
519880425

ZxID:1907779

等级: 少将
水太浅不够潜

举报 只看该作者 8楼  发表于: 2009-03-14 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
太长太深奥..
304355668

ZxID:2687891

等级: 大尉
谁若97岁死,奈何桥上等三年

举报 只看该作者 9楼  发表于: 2009-03-14 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
看下看下
勇士在猴岛

ZxID:4741021

等级: 准尉
举报 只看该作者 10楼  发表于: 2009-03-14 0
Re:▲▲用WPE制作外挂实例  (转) (申请点亮)
眼花了...
« 返回列表
发帖 回复