标题:
[讨论]
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
[打印本页]
作者:
逆灵
时间:
2009-4-29 16:46
标题:
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
+ U1 H5 t( `/ s—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
妖城在线论坛2 x- C/ [, V( x5 \; n+ T
相信现在很多人的数据库都会出现重名角色被替换的情况。
$ t. F- e b8 U; r魔力私服,最新魔力宝贝私服技术交流
这种情况实际上是由数据库中的几个字段造成的,
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート/ T3 U9 v! X/ V/ O6 J% {+ Q
首先我们来分析一下数据库表
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1 h, z5 ?- g6 T
9 H/ D6 a) t% H) G妖城在线论坛
tbl_user 这个 是存放角色登入账号的。其中包括:
妖城在线论坛 v t: J; U) P' E0 }
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
5 ~" V, f) J$ R+ K魔力私服,最新魔力宝贝私服技术交流
9 e& K! x& @" s# H
这里基本英文大家也明白了
妖城在线论坛. O/ j; c$ V) k9 g) `7 F
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
$ R. V% E* S/ p2 O
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表! g. M1 H- Y# E8 ?; d
这个字段直接影响到
9 M% G# X4 v! Z% F2 \' a1 ?$ N/ o魔力私服,最新魔力宝贝私服技术交流
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
0 L6 X( Y4 K- W/ v1 |% `1 k/ o& ]妖城在线论坛
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
1 u6 b: i1 O: L; |魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
2 n' l$ k( w: `0 n魔力私服,最新魔力宝贝私服技术交流
bbs.mocwww.com' w7 ^3 I6 b: f% `9 Q5 V, T6 `
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート) g" f. r# q4 H3 R
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表+ f. F+ n$ p5 C/ Q
而
& {* o5 H/ G ?5 b( Z魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表0 D" X" u% a7 U8 X( @8 T" w
所以
7 ~2 x# Z. V0 Q) j魔力私服,最新魔力宝贝私服技术交流
恢复人物的方法是。
% G3 |" _% X8 r0 }
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
& U' X# b! `, h8 `妖城在线论坛
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
' k; j: B' A& I5 D$ ]1 L9 [妖城在线论坛
这个RegistNumber 在tbl_skill的第二个字段也一样。
妖城在线论坛9 B7 j* F$ p7 G h
决定了该人物的技能
妖城在线论坛: y9 f k- i# A* d; S9 S( ?; J
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
7 U# Y2 h7 E5 F4 r8 v魔力私服,最新魔力宝贝私服技术交流
3 @# \5 _$ M2 e9 U/ m魔力私服,最新魔力宝贝私服技术交流
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
) u* `2 C" f) |; g魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
方法如下 打开注册网站的注册页
妖城在线论坛7 p4 B; k6 [" A) b$ }* o, b
找到这一行SQl语句:
bbs.mocwww.com( ]% R! S$ F( i* r
! X8 v+ n! m/ ~. _% ~
$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')";
8 A& |0 R4 @7 o4 A" h/ w$ n
0 S% W0 S9 i& d& X3 O. L( y5 e魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
后字段的 '100'就是 创建人物序号
/ F( a8 [& ?, _4 [, z$ m1 {$ V6 hbbs.mocwww.com
自己更改即可造成重复也不会消失的人物。
/ k6 S& K9 ]- N妖城在线论坛
; l* T9 ~9 a$ a, y) h0 Q% V& L4 j
给高手们的建议:
8 E& _- D; h6 P% v6 U' l3 ^- q妖城在线论坛
由于本人的汇编很烂(我搞C++的)
, u( B5 u4 {, b. h
所以不想研究gmsv或者cg_190的 IDA反汇编编译。
bbs.mocwww.com8 _$ |0 b) G& K, d, w) `' q3 z8 x
bbs.mocwww.com* k+ p5 v) ?; P0 q$ Q1 Z* g
懂这方面的朋友可以进行以下操作:
8 M8 m2 ]6 t7 \5 Y2 }( q魔力私服,最新魔力宝贝私服技术交流
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
0 |/ N1 F* }; P$ w; _魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
7 J( ?/ f: L( S" c% q
这样的话还是允许重名,但至少不会再删除。
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート/ \: V' g# F1 @2 [, F0 C; p; o9 \- J
d# P/ e+ O: F妖城在线论坛
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
- F; t, v' T& Z1 ?9 ]魔力私服,最新魔力宝贝私服技术交流
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
7 O h0 @% i5 p k& _: zbbs.mocwww.com
希望能共享一下 谢谢。
作者:
黄昏
时间:
2009-4-29 19:08
嗯 之所以会删除是因为创建角色的语句为
" A8 g V, V& l$ @—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
REPLACE tbl_character VALUES……
妖城在线论坛" u3 a5 V) O$ o6 d6 J6 |0 W
查mysql手册可知
/ A1 `: N9 H; o4 E6 w! B. C# p7 W魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
0 v) P# i h6 r( F
嗯 解决方法论坛里面有人很早就发出来了…… 去掉name的索引就可以了……
' Y7 L# O5 c9 ?; v4 V1 l—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
: a% G2 x3 }' y8 |
不过这样不删除数据,但是还会有重名的角色存在
妖城在线论坛" W Q1 D( t* X
完善的解决方法可以从2方面考虑
bbs.mocwww.com+ U& ~& }/ P; v7 j5 [& b
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
. ], M! r6 Z- D( F魔力私服,最新魔力宝贝私服技术交流
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者:
逆灵
时间:
2009-4-30 01:40
我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
魔力私服,最新魔力宝贝私服技术交流 G9 ?! {* z. o7 i& h, c2 r- U
和Name一样 就一定会被删除
欢迎光临 妖城在线论坛 (http://bbs.mocwww.com/)
Powered by Discuz! 6.0.0