发新话题
打印

[讨论] 【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。

【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~妖城在线论坛6 o+ N& |. ?, v: ?
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表, f* G% ?0 G! D+ x7 F
相信现在很多人的数据库都会出现重名角色被替换的情况。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート4 U, g- ]. I8 }  a
这种情况实际上是由数据库中的几个字段造成的,
8 T4 y6 Q$ X; y# N3 O" p$ H0 j$ \% p. v首先我们来分析一下数据库表. Y3 y$ ]' O* w' e3 h2 q2 l
bbs.mocwww.com+ }+ x) O. H$ t% }8 M% S
tbl_user 这个 是存放角色登入账号的。其中包括:妖城在线论坛; b; U. Y1 _  ~0 w$ g
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
. ~- S" ^5 M/ o9 a6 ~魔力私服,最新魔力宝贝私服技术交流—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート, v" q; \, k: N- I2 ]6 q6 v
这里基本英文大家也明白了 : W1 l- u' t5 `- T# B5 s, t1 ]
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是魔力私服,最新魔力宝贝私服技术交流  k; K( T  e# |0 Y6 T
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
8 B& o4 k- I* m% m( lbbs.mocwww.com这个字段直接影响到
2 F! c" w, ^2 u. h& k- \, y—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートtbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表6 ?  ^$ T9 ?: T! I4 h7 r
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
8 T' h0 {1 ?% f$ p魔力私服,最新魔力宝贝私服技术交流就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
( ]- J! M/ F" H6 }. f' m, ubbs.mocwww.com妖城在线论坛" ?* K# G, w1 l+ R7 y" V
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。bbs.mocwww.com& @. K0 I7 k" W) X; [# H

3 d$ r0 ?( S( M7 ^' T1 D7 \魔力私服,最新魔力宝贝私服技术交流& }8 u" N2 s" z2 l. ?1 A7 s6 L
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。6 m/ h8 ?, x; u/ g% O
所以
( S  C$ O. y, I& [, ~, i妖城在线论坛恢复人物的方法是。
6 s) u4 r5 K0 k& k魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
$ [4 h3 Z# m: V( D: b5 x' c4 sbbs.mocwww.comtbl_item 中的 该账号原来角色的 RegistNumber 相同 即可魔力私服,最新魔力宝贝私服技术交流5 F* K+ Y# a: e1 V. {, l
这个RegistNumber 在tbl_skill的第二个字段也一样。bbs.mocwww.com# U) T6 P' B7 e$ f8 Y2 d* m' F
决定了该人物的技能 bbs.mocwww.com6 o3 P3 t* K8 M' s5 `
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
. o; A$ v& R5 D. }  b  ]& S$ \
$ z! I+ ?' w' O6 X1 b3 m小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了" ?: c/ ?# o+ r  `8 }9 F' c3 @5 c4 A
方法如下 打开注册网站的注册页
1 B$ {# G5 K3 u2 ^% z% a( dbbs.mocwww.com找到这一行SQl语句:
3 G# T& }7 \6 Q: g
  g8 j0 ?5 k0 T: w' k0 k, i, F5 _—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート$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')";
  _  t+ U" E: m5 D. ^$ @魔力私服,最新魔力宝贝私服技术交流
/ Q. r, q  p0 y' g/ H0 ebbs.mocwww.com后字段的 '100'就是 创建人物序号bbs.mocwww.com: f1 R* F- o$ z/ l+ y" _
自己更改即可造成重复也不会消失的人物。
( E7 E- e5 ?' c( z% g魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
) U6 K* U* y' ^% J# E给高手们的建议:妖城在线论坛/ V# z; n9 Y% O- e$ J8 z
由于本人的汇编很烂(我搞C++的)魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表' W4 F. ^/ b% i* n
所以不想研究gmsv或者cg_190的 IDA反汇编编译。% Q/ x8 S. {7 H$ {7 g7 a

$ c1 `- F, [# B/ Y9 x9 u  T—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート懂这方面的朋友可以进行以下操作:
' Z2 S2 i+ i9 R- `# V5 x魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。/ ^6 Y0 B1 ~3 w5 i
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
# v' G* d' X/ Q+ E这样的话还是允许重名,但至少不会再删除。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート4 z9 N  a8 U# S$ }; e' Y4 g% E

, y$ A. A+ H+ f$ q; k! q—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲートPS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
8 d# N6 O7 p) a( s7 d—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
: C% n, L6 V8 G# g8 `) L希望能共享一下 谢谢。
本帖最近评分记录
  • 完美汉化 妖力 +5 继续别停,参考下黄昏 2009-4-30 08:15

TOP

嗯 之所以会删除是因为创建角色的语句为
: k# x# _$ }  C; [REPLACE tbl_character VALUES……bbs.mocwww.com" ~2 q9 O7 |% g+ A- J( w) K7 d
查mysql手册可知bbs.mocwww.com2 `2 ]5 A. k- H+ X9 A
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表9 b! ]/ X- C/ f. k' [3 i6 t- J
嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート/ g% {2 T; p) z* _3 v

- \+ H* o$ K5 W, {- d: ?/ u—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート不过这样不删除数据,但是还会有重名的角色存在
& l( z. u* f0 I8 }8 ^完善的解决方法可以从2方面考虑
2 B- H6 k" h7 S% R魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表  N5 V9 f4 p3 v/ Y$ |
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
本帖最近评分记录
  • 完美汉化 妖力 +1 的确是这么回事 2009-4-30 08:14

在我今日的悲伤里,最为苦涩的是我昨日欢乐的回忆。

TOP

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
: x3 t+ g, B1 l9 p妖城在线论坛和Name一样 就一定会被删除

TOP

发新话题