标题:
[讨论]
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
[打印本页]
作者:
逆灵
时间:
2009-4-29 16:46
标题:
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
bbs.mocwww.com/ j& f- O( L* x# y! f: R2 J% ?$ s
妖城在线论坛8 K3 i" s4 K3 Z% [2 p$ Q
相信现在很多人的数据库都会出现重名角色被替换的情况。
bbs.mocwww.com0 v* f1 Z$ V; r8 `" T9 a
这种情况实际上是由数据库中的几个字段造成的,
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート- l c6 W" k" g3 d4 y9 q) Q6 W
首先我们来分析一下数据库表
6 w- w! P: h# V4 \
9 z6 x5 b. Q' P2 w- T! b V9 ^魔力私服,最新魔力宝贝私服技术交流
tbl_user 这个 是存放角色登入账号的。其中包括:
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート7 {/ j8 S8 Y# w! t9 \' }% H
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
魔力私服,最新魔力宝贝私服技术交流" s8 A; x+ _# ^5 h
1 i0 B; B: z( _& [) U- r妖城在线论坛
这里基本英文大家也明白了
' F1 j3 ^6 p9 L2 a
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
. {7 G; A4 V- g魔力私服,最新魔力宝贝私服技术交流
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
/ C1 ^6 C; B+ ~2 \魔力私服,最新魔力宝贝私服技术交流
这个字段直接影响到
- ^; l- X, n) x" K$ u
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
: S% x( @& b: X6 [& V D/ \7 c+ f妖城在线论坛
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
6 ?6 v- v& |$ m6 l x- v) |) K魔力私服,最新魔力宝贝私服技术交流
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表" ?+ o9 k5 Z0 T" y4 Y
5 s$ q! \0 T, [ y3 e, ybbs.mocwww.com
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
5 t: V' u+ r; U) S( j! ]魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表% C& z; b' Z, @
而
6 A- ?6 }1 [, J/ \$ E L0 |
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート3 p# ?; B( Y" f2 c% e7 R
所以
) e, w+ W* J8 D% W7 F, F魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
恢复人物的方法是。
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表% l9 x6 d6 w7 q3 e' g( ~- s. N
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
魔力私服,最新魔力宝贝私服技术交流' g4 i8 {6 ]( r: U; e2 t/ I, ]/ ]
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
' ]; u7 U1 z4 U* P3 F9 r' L—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
这个RegistNumber 在tbl_skill的第二个字段也一样。
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 y4 m5 {* `* o% q
决定了该人物的技能
. q6 `8 ?+ U! P, \# ]魔力私服,最新魔力宝贝私服技术交流
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート9 Y- p/ f1 H' {' }) F9 p
4 u8 ]6 A4 `" t8 L: w7 V1 P( r4 p0 Ubbs.mocwww.com
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表5 j7 z9 v: z# r
方法如下 打开注册网站的注册页
7 G* i k; l/ c% [5 Y0 X—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
找到这一行SQl语句:
7 w' I. d4 f9 A1 _魔力私服,最新魔力宝贝私服技术交流
1 C+ _ {0 h" x2 d) `! o Z
$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')";
2 f! o* s2 p8 N4 S5 L8 z* K: I妖城在线论坛
妖城在线论坛- e2 U4 `$ u( Y$ {3 g* Y# W
后字段的 '100'就是 创建人物序号
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート" I& F- Q9 `" V! F
自己更改即可造成重复也不会消失的人物。
# C( e$ ~2 {! c2 f* x5 q4 |& e% ?bbs.mocwww.com
: E( c' A5 C( P1 |2 `) A& F魔力私服,最新魔力宝贝私服技术交流
给高手们的建议:
魔力私服,最新魔力宝贝私服技术交流7 G4 q! O* B( R0 O. F* \
由于本人的汇编很烂(我搞C++的)
* u( u- i( ^2 u- S妖城在线论坛
所以不想研究gmsv或者cg_190的 IDA反汇编编译。
. M/ Q9 H4 l7 ] n% V3 U; I魔力私服,最新魔力宝贝私服技术交流
妖城在线论坛! _1 V$ d5 c* e# N: e
懂这方面的朋友可以进行以下操作:
魔力私服,最新魔力宝贝私服技术交流8 l" I ?- h( K! p5 B: W0 W
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 @4 S$ {0 s( [8 T) T
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
bbs.mocwww.com D- W- ?' W4 K/ Q
这样的话还是允许重名,但至少不会再删除。
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート9 ^1 N9 ~$ @! b% Q. A* s" }
魔力私服,最新魔力宝贝私服技术交流: c/ R N" g N" u
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
bbs.mocwww.com1 Z6 z. q5 d& r, j _6 u
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
3 l) K a4 i$ f+ E7 E; U9 R9 L妖城在线论坛
希望能共享一下 谢谢。
作者:
黄昏
时间:
2009-4-29 19:08
嗯 之所以会删除是因为创建角色的语句为
/ G2 P% l9 P5 z* ~9 A) A; f妖城在线论坛
REPLACE tbl_character VALUES……
7 D0 F" d5 W( e2 }) Z. ~$ Z( }妖城在线论坛
查mysql手册可知
魔力私服,最新魔力宝贝私服技术交流( ^) Y1 \( R6 e# T d
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
妖城在线论坛7 e/ O* r9 O& \8 | n7 { D4 Z
嗯 解决方法论坛里面有人很早就发出来了…… 去掉name的索引就可以了……
/ Q/ G0 K+ b7 e( T- q魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
6 z2 U& c, P7 G+ h( T3 b# d0 F4 U
不过这样不删除数据,但是还会有重名的角色存在
1 F" l8 \7 r3 S/ f" g# rbbs.mocwww.com
完善的解决方法可以从2方面考虑
bbs.mocwww.com5 k+ X2 u% N4 V/ q6 d+ t
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
4 [! n' y3 F' D# Lbbs.mocwww.com
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者:
逆灵
时间:
2009-4-30 01:40
我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
6 ]1 n; z' h4 F6 v4 n7 \
和Name一样 就一定会被删除
欢迎光临 妖城在线论坛 (http://bbs.mocwww.com/)
Powered by Discuz! 6.0.0