标题:
[讨论]
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
[打印本页]
作者:
逆灵
时间:
2009-4-29 16:46
标题:
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
bbs.mocwww.com1 ?2 e7 b3 q. V; {- I! w
* T# M' S% f( Z' t. s$ c魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
相信现在很多人的数据库都会出现重名角色被替换的情况。
妖城在线论坛+ R9 x( O) |: K- z5 y3 E! \
这种情况实际上是由数据库中的几个字段造成的,
. x' Q4 K5 x7 P5 `妖城在线论坛
首先我们来分析一下数据库表
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート5 T% ^ y: P4 @2 H6 b3 ^. A
, S3 d2 q8 U n) u1 _3 {0 f/ m魔力私服,最新魔力宝贝私服技术交流
tbl_user 这个 是存放角色登入账号的。其中包括:
" b! [7 s2 d+ a. x2 }bbs.mocwww.com
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
# L4 H; m1 j- L( J
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート& D% v3 }; a7 J5 I2 X9 v3 d
这里基本英文大家也明白了
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート9 ^. U, a" n& v6 f2 d: E H
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
0 W( x0 G1 i' _3 [* Nbbs.mocwww.com
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 a4 x- V7 O7 d2 E4 K$ m( z
这个字段直接影响到
- _7 t& w9 p& b7 L" E' e妖城在线论坛
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
" E7 m: D e% r, L+ a2 S% b—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
6 b) I+ Z" |( Y# U( W魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
& B6 u9 b9 M; W$ o; Q—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
# {8 _7 ], Q' ^9 Z0 Q
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
8 N4 U5 @2 s" o; z& g2 g2 U
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表4 Z( G" h( p+ z& q
而
bbs.mocwww.com9 f$ P. p+ C5 \! x
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
7 U; `7 Z2 x6 {/ M$ ?妖城在线论坛
所以
: g; |1 c6 H0 c# M: N妖城在线论坛
恢复人物的方法是。
妖城在线论坛1 A) L$ W* y! a$ r
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
魔力私服,最新魔力宝贝私服技术交流9 R# L+ g0 ]" g4 u
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
6 E( b+ g( I/ A! M3 ?+ f妖城在线论坛
这个RegistNumber 在tbl_skill的第二个字段也一样。
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表. X; G/ D7 c* U7 F( C' W) m
决定了该人物的技能
( z* g' v' t! d7 N" R) s+ |; U
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
bbs.mocwww.com$ I0 j( A' ^/ t/ {! ^ j, j6 S
魔力私服,最新魔力宝贝私服技术交流2 i' u2 b- N5 Y9 i+ t' a6 F% w. X0 o' _
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
- {% H( ^2 r5 H0 q; l
方法如下 打开注册网站的注册页
% Y0 S6 P% H' j* f0 Y" c7 b: }* F魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
找到这一行SQl语句:
5 U' z5 T. `) q- [7 `# b妖城在线论坛
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表 L6 o9 o: X1 u! P; q, @# o; o2 \) `6 v# |
$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')";
妖城在线论坛6 v0 C2 `. O2 ]4 {/ l
7 v: M7 ^9 J4 M7 v. F& t V2 ~
后字段的 '100'就是 创建人物序号
0 X( ^- u& p7 \# s! `* o! G
自己更改即可造成重复也不会消失的人物。
魔力私服,最新魔力宝贝私服技术交流0 [3 A- j6 f3 L: V7 r5 g! p
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表7 Z4 P. V3 j# y; h# y, T6 z
给高手们的建议:
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート6 q: c6 J2 V r
由于本人的汇编很烂(我搞C++的)
bbs.mocwww.com; y5 A8 ], ?* [& v; G% \. Y9 E
所以不想研究gmsv或者cg_190的 IDA反汇编编译。
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表% R, I) W6 R/ Q5 |# p
% k4 Z! h& R# Y6 I/ o: ?# {
懂这方面的朋友可以进行以下操作:
4 K& F+ x2 f1 |& |* w) j, v魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
& k5 O6 h! p1 f) M- u魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
) Z5 P, T9 E% S4 y: H0 j( o魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
这样的话还是允许重名,但至少不会再删除。
bbs.mocwww.com1 o; C$ ? r: l9 a- ?/ |# V
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート: @$ I$ k, f5 G4 v3 w! D5 ~, A
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
: i1 a8 d: h) ~4 R- c9 A, m7 i. Z魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
bbs.mocwww.com* H& h" Z6 ~8 o( l& B
希望能共享一下 谢谢。
作者:
黄昏
时间:
2009-4-29 19:08
嗯 之所以会删除是因为创建角色的语句为
% u7 } G% a6 Q' L+ ?. k' r
REPLACE tbl_character VALUES……
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表! O0 J' Y1 o+ o$ C( j( H
查mysql手册可知
( s$ N0 @6 B! y4 o妖城在线论坛
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
% x. k6 k4 ]" b2 u4 }妖城在线论坛
嗯 解决方法论坛里面有人很早就发出来了…… 去掉name的索引就可以了……
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表6 X( q I* [7 f8 G1 L
. J9 ]) _0 L* {( `4 K
不过这样不删除数据,但是还会有重名的角色存在
5 n. y7 C- b' b4 a6 X魔力私服,最新魔力宝贝私服技术交流
完善的解决方法可以从2方面考虑
4 D4 x3 ` J$ O' v* a, l魔力私服,最新魔力宝贝私服技术交流
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
1 R P6 ~/ p# M3 |bbs.mocwww.com
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者:
逆灵
时间:
2009-4-30 01:40
我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表9 B0 @- I Y% v
和Name一样 就一定会被删除
欢迎光临 妖城在线论坛 (http://bbs.mocwww.com/)
Powered by Discuz! 6.0.0