标题:
[讨论]
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
[打印本页]
作者:
逆灵
时间:
2009-4-29 16:46
标题:
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
魔力私服,最新魔力宝贝私服技术交流3 z+ G; i$ T( [' V
# _7 l$ M1 L) y- g* R—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
相信现在很多人的数据库都会出现重名角色被替换的情况。
妖城在线论坛/ H& L$ H# t# \0 T9 W8 J$ q
这种情况实际上是由数据库中的几个字段造成的,
5 w* z" b7 u9 J6 O' h
首先我们来分析一下数据库表
" }. V% h m% g0 _- ~( N2 F3 P魔力私服,最新魔力宝贝私服技术交流
: H" |" f0 L: @& ?' H( g
tbl_user 这个 是存放角色登入账号的。其中包括:
bbs.mocwww.com7 [* B8 u/ _7 E; {- w: ]
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
" d6 m5 e6 j4 N1 Y9 l5 p5 N7 c) d魔力私服,最新魔力宝贝私服技术交流
* {' V2 ]9 B4 l# r- Z魔力私服,最新魔力宝贝私服技术交流
这里基本英文大家也明白了
- W1 P6 `7 [- S( W: [4 O8 V妖城在线论坛
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
# Z! A" F; a/ d8 M妖城在线论坛
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表+ {/ `' l+ ^, j! k c" E. n
这个字段直接影响到
1 E/ x, y4 M* f/ A6 b. w' N魔力私服,最新魔力宝贝私服技术交流
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表2 f8 W: v" M O6 F' Y2 O' }
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
! J' b, i5 Z2 D, H {6 v5 j
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
3 Z) p8 @" Z* L- O& J
) m' p9 g8 A( F) J8 s" p! L1 H
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
$ @( q2 { j/ T8 s( v" A- c魔力私服,最新魔力宝贝私服技术交流
( G- {' g1 ]" M, ?妖城在线论坛
而
; r/ r, } o) H2 U9 ^8 K6 d( F$ _魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
妖城在线论坛3 l+ _& n' U' z6 W9 g# Z
所以
* }# f3 L$ ^4 M- j! R/ v, a6 ~" I
恢复人物的方法是。
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表0 {% u0 n" a( O# C! Y
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
妖城在线论坛1 X2 w2 }( W% F
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
bbs.mocwww.com3 S/ o0 ^3 ~2 M
这个RegistNumber 在tbl_skill的第二个字段也一样。
魔力私服,最新魔力宝贝私服技术交流# M0 n' u: e& G& E
决定了该人物的技能
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表2 F* w: Z( Z% L' T7 P
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
1 `: {" Y1 Q; z1 k) x( hbbs.mocwww.com
妖城在线论坛& p& z- E' P) r5 G
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
魔力私服,最新魔力宝贝私服技术交流& D) \( K5 ] b
方法如下 打开注册网站的注册页
2 c$ x( w$ A! J魔力私服,最新魔力宝贝私服技术交流
找到这一行SQl语句:
& V' J: ~6 p1 s
: `* T) u( j; z3 \7 ]魔力私服,最新魔力宝贝私服技术交流
$sql2="insert into tbl_user (AccountID,AccountPassword,EnableFlg,TrialFlg,DownFlg,ExpFlg,SequenceNumber,UseFlg,BadMsg,CdKey,safeword,RegTime,ip,HellScore) values ('$id','$pass','1','8','0','0','100','1','0','$id','$mlhy','$data','$userip','$regscore')";
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート1 E, C. Y. d0 Z5 o! j+ Y/ Z
, t! r( \ p, Q魔力私服,最新魔力宝贝私服技术交流
后字段的 '100'就是 创建人物序号
魔力私服,最新魔力宝贝私服技术交流$ s3 ~, k H! k( [% ]
自己更改即可造成重复也不会消失的人物。
' s' Y+ L+ r; J9 {' x
魔力私服,最新魔力宝贝私服技术交流( e+ \- M! T# S' U9 A R9 @! X. C
给高手们的建议:
bbs.mocwww.com7 Q! ?, D7 Q) a) ^6 B9 L
由于本人的汇编很烂(我搞C++的)
8 ]7 H0 c1 Z8 Q. A# A) X n$ P魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
所以不想研究gmsv或者cg_190的 IDA反汇编编译。
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート. X1 C2 {- Q( J
魔力私服,最新魔力宝贝私服技术交流- V8 C+ E1 v7 I5 q
懂这方面的朋友可以进行以下操作:
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート7 q! d0 C" t1 r+ p, w
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
5 d: Q) e! f: `# q# }% ?
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
魔力私服,最新魔力宝贝私服技术交流' M( T) p1 F2 A% }! s
这样的话还是允许重名,但至少不会再删除。
$ I( k* }- q+ C( b6 V7 ]妖城在线论坛
& a) ^! L* |7 w! {8 @, A魔力私服,最新魔力宝贝私服技术交流
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
; E; Y' |9 ?) d& d* l
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
) [$ ~$ Y6 h5 @3 W+ t6 U: @. G b
希望能共享一下 谢谢。
作者:
黄昏
时间:
2009-4-29 19:08
嗯 之所以会删除是因为创建角色的语句为
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート$ Q) @" P: ^+ z5 P5 [0 r6 i- [
REPLACE tbl_character VALUES……
6 l; E& l; W6 x- {魔力私服,最新魔力宝贝私服技术交流
查mysql手册可知
5 m7 j, S$ O" A7 C—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
bbs.mocwww.com' } V9 w# o, q0 {! y
嗯 解决方法论坛里面有人很早就发出来了…… 去掉name的索引就可以了……
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート+ y+ V+ d; e# r9 F* N. v" q( o2 T5 K
bbs.mocwww.com" R. P* {9 W- f- M' ^+ D3 o
不过这样不删除数据,但是还会有重名的角色存在
! }/ T7 a: }1 t魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
完善的解决方法可以从2方面考虑
. \1 B, b( F ~6 E3 ]魔力私服,最新魔力宝贝私服技术交流
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート9 |) E; X$ f! P) y2 g/ `
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者:
逆灵
时间:
2009-4-30 01:40
我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
f% c7 x: N- i! k+ i. e5 z
和Name一样 就一定会被删除
欢迎光临 妖城在线论坛 (http://bbs.mocwww.com/)
Powered by Discuz! 6.0.0