标题:
[讨论]
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
[打印本页]
作者:
逆灵
时间:
2009-4-29 16:46
标题:
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
) E7 Z# Z+ f, o2 M; V5 F魔力私服,最新魔力宝贝私服技术交流
6 }/ b+ R; z0 i |+ {% G) c—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
相信现在很多人的数据库都会出现重名角色被替换的情况。
bbs.mocwww.com+ A% B4 j/ ^8 G# K3 r. Q
这种情况实际上是由数据库中的几个字段造成的,
' E- O9 y j9 L1 X
首先我们来分析一下数据库表
魔力私服,最新魔力宝贝私服技术交流# h# ?# h- _( `9 k: p1 ^+ i& a( T
7 I0 P. l% Y; |
tbl_user 这个 是存放角色登入账号的。其中包括:
4 p4 @& F$ {. Q妖城在线论坛
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
]% V' E' Q4 \" `- I1 k—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
6 Z8 v! m z5 I2 L妖城在线论坛
这里基本英文大家也明白了
8 Y+ I1 Y2 |7 U9 T4 h5 E$ K1 `
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
0 Z# y+ j( ~5 ]* z- H7 t4 N
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
: l( N) Q/ L; F( Z k; ?! L5 h魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
这个字段直接影响到
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表' F& x% u, Q+ i3 u
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート0 N3 V& n0 n' i% O5 F
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
0 l1 o. g! w2 c* ?, |- N' abbs.mocwww.com
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( t. l) G. W' H' W, o
bbs.mocwww.com5 c- ]6 a2 X, t( Z M0 a
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
$ a c9 u. D, R* p" |7 _—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
* a" [ j- Z6 a, Q$ J9 g—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
而
魔力私服,最新魔力宝贝私服技术交流0 G7 ?0 t: E! r5 z2 W. @
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
bbs.mocwww.com4 Q- n2 T% l7 [; ]: l0 |
所以
魔力私服,最新魔力宝贝私服技术交流1 _: F: i! g; d& h9 d- ^3 b4 D
恢复人物的方法是。
bbs.mocwww.com6 {* U7 ?" J6 y/ z
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
妖城在线论坛% m4 }* u3 K* y# U3 T! E Y# C
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
. M$ P4 ^& q( g8 s* G1 U% z+ Z: N7 h—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
这个RegistNumber 在tbl_skill的第二个字段也一样。
- f1 n' y5 z" k
决定了该人物的技能
bbs.mocwww.com9 C9 \' B! d5 p
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
妖城在线论坛5 S# y0 C# d# i
: j2 z" V" v; U% p妖城在线论坛
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
' L4 N* Y7 L) V/ @8 \魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
方法如下 打开注册网站的注册页
bbs.mocwww.com4 A S9 h/ V0 D
找到这一行SQl语句:
bbs.mocwww.com# v+ O+ [' H! b; l
& _- D$ a; B+ {魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
$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')";
* G; O3 K) Z2 w% I2 z/ x5 l; |- z* t
2 t4 a4 R, T V—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
后字段的 '100'就是 创建人物序号
; u+ Q9 f& E+ s! u2 ?
自己更改即可造成重复也不会消失的人物。
( d/ K Z Q7 }. E: o) S d* B魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
. `+ I! I! c3 U( y魔力私服,最新魔力宝贝私服技术交流
给高手们的建议:
" w2 r8 R# ~. i+ F6 [. b% abbs.mocwww.com
由于本人的汇编很烂(我搞C++的)
1 a+ n( F. G& O妖城在线论坛
所以不想研究gmsv或者cg_190的 IDA反汇编编译。
& ~* M5 x. v" b/ \2 ~妖城在线论坛
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表& d2 c( T3 d) [+ @( J
懂这方面的朋友可以进行以下操作:
3 y8 z2 A+ B# ]2 Y+ f- w魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
- q2 t9 k2 T: t5 g魔力私服,最新魔力宝贝私服技术交流
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
* s/ R9 j/ j6 S# q' s妖城在线论坛
这样的话还是允许重名,但至少不会再删除。
bbs.mocwww.com7 k m) z0 a* n6 q, @$ u7 W
# q5 ^, d, G8 O: M妖城在线论坛
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
魔力私服,最新魔力宝贝私服技术交流; [, L) P1 [% ^+ x4 A- |
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
8 o9 F' ?, s$ c$ Jbbs.mocwww.com
希望能共享一下 谢谢。
作者:
黄昏
时间:
2009-4-29 19:08
嗯 之所以会删除是因为创建角色的语句为
+ `) |% ]. n8 V) q1 ~
REPLACE tbl_character VALUES……
! G. C, D+ B; Q—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
查mysql手册可知
$ G! Q' a3 g6 J. T- m—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
bbs.mocwww.com0 l0 W+ N8 ?' n" H3 \7 @5 W
嗯 解决方法论坛里面有人很早就发出来了…… 去掉name的索引就可以了……
! _( _/ C( I1 J0 C5 }5 \' a( f妖城在线论坛
1 D2 T" y: X$ M/ g0 o: w魔力私服,最新魔力宝贝私服技术交流
不过这样不删除数据,但是还会有重名的角色存在
bbs.mocwww.com7 x5 u, k: {4 W* `9 ~, k
完善的解决方法可以从2方面考虑
/ {8 k2 R6 j: m2 K* Kbbs.mocwww.com
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
* m( L! b/ p% d魔力私服,最新魔力宝贝私服技术交流
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者:
逆灵
时间:
2009-4-30 01:40
我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
bbs.mocwww.com- a, V; L$ t0 S
和Name一样 就一定会被删除
欢迎光临 妖城在线论坛 (http://bbs.mocwww.com/)
Powered by Discuz! 6.0.0