Board logo

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

作者: 逆灵    时间: 2009-4-29 16:46     标题: 【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。

PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 k* ]$ u! Z9 _( s- M( V1 l# y

8 F9 \2 q1 E. I6 u0 K—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート相信现在很多人的数据库都会出现重名角色被替换的情况。—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート, L4 s9 h3 n/ y( j4 I
这种情况实际上是由数据库中的几个字段造成的,—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート7 [& Y# ]* Z1 m$ G% v
首先我们来分析一下数据库表
6 b* w- a6 ?' @2 G% i' _bbs.mocwww.com
/ ?, w6 a2 ~) q魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表tbl_user 这个 是存放角色登入账号的。其中包括:
' K: Q8 j! f4 [! k4 m" hbbs.mocwww.comAccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
% m  J" S8 m1 A) v- T9 l4 Wbbs.mocwww.com
  h* ]/ {/ t! G. E$ O. pbbs.mocwww.com这里基本英文大家也明白了 魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表( V, f0 I( p. v) r. {: l
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是bbs.mocwww.com' g7 E) J4 |- m. s! a
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减 / @4 o' M' y$ p. l) p% S
这个字段直接影响到9 i/ \+ h! n" Q& Y* \+ ^2 [
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
2 h. {' I6 i* ^8 P1 B3 e( j  B" Rbbs.mocwww.com实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
; W/ H4 J% ~2 c就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
  t' R) f1 @' M% [: f+ @  T妖城在线论坛妖城在线论坛7 s/ W4 ^% K( V% I$ X1 _
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
" d/ O# r) a) N魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
, N) R9 F' z7 u( _) W+ w
, W7 s  O2 L) {" Ntbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
0 t8 y# @' ^7 Obbs.mocwww.com所以—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート6 q* ]/ k* Z9 J" o0 v+ \7 |/ {
恢复人物的方法是。妖城在线论坛7 T0 i5 e7 l  `7 L- \
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1 l1 \- t" F5 K* U2 h3 U
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート  s' g7 O1 N  O2 v: R5 C4 h
这个RegistNumber 在tbl_skill的第二个字段也一样。
- A4 U1 o; e! x2 k, k魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表决定了该人物的技能
$ ?' D  U+ L6 R1 n—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表# R  t) h/ W$ w) {

, A" @3 `" d+ a) M% X: f—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表; w  p3 v' @* ~! \8 z% `
方法如下 打开注册网站的注册页
4 B, F5 u' W. `$ W—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート找到这一行SQl语句:
4 Z/ J) V0 X- W% `$ c2 [魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
2 ~. t; M9 z: u7 U8 H魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,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')";
" i2 x% R# Z) B# t, ^* T; |妖城在线论坛( |8 F1 i3 ]& c; I7 _
后字段的 '100'就是 创建人物序号魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表: B# L6 k2 |) W4 Q+ l  Y
自己更改即可造成重复也不会消失的人物。
+ K! }7 i3 l, h  ?. J' ^bbs.mocwww.com
% ]; `/ c( Y& G% J. ]: M6 Ibbs.mocwww.com给高手们的建议:魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表& \2 E( q) g, q6 n, q7 f
由于本人的汇编很烂(我搞C++的)bbs.mocwww.com! U( e% J9 f1 s# o: D' }! X
所以不想研究gmsv或者cg_190的 IDA反汇编编译。魔力私服,最新魔力宝贝私服技术交流# J& {* H. v' N1 e* d

3 {. Z( m' z( g: |; z+ d魔力私服,最新魔力宝贝私服技术交流懂这方面的朋友可以进行以下操作:
- |% ~5 K( R) D; d妖城在线论坛1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
, {9 O: {/ @$ f6 j! d. L5 p魔力私服,最新魔力宝贝私服技术交流2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
9 W" {# v" [$ i—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート这样的话还是允许重名,但至少不会再删除。
3 l- g( v. L5 V, O/ D魔力私服,最新魔力宝贝私服技术交流
1 s4 }/ G% l# |% o! x$ dPS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。魔力私服,最新魔力宝贝私服技术交流/ {. ~5 F8 O9 I- I, w# f& W
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表) }3 Y5 }0 t0 y- _: W' t
希望能共享一下 谢谢。
作者: 黄昏    时间: 2009-4-29 19:08

嗯 之所以会删除是因为创建角色的语句为
0 @$ y# z# a- x- X8 J# \妖城在线论坛REPLACE tbl_character VALUES……魔力私服,最新魔力宝贝私服技术交流; P2 m" S7 _' n# C# @. P# _+ G
查mysql手册可知魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表: L( x7 ^  a4 L* }# H# {# R/ T
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
- e/ d$ ?! [4 f% p9 [( p* ~, ^bbs.mocwww.com嗯 解决方法论坛里面有人很早就发出来了……  去掉name的索引就可以了……魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表/ I* i* B% Z+ U; F
妖城在线论坛/ c: T( \, d, O2 C
不过这样不删除数据,但是还会有重名的角色存在bbs.mocwww.com# X  j: i4 r% j8 X! o  p
完善的解决方法可以从2方面考虑bbs.mocwww.com  Z2 P( T2 j% B3 q/ G" z5 S
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)bbs.mocwww.com7 d/ s% R5 @( @2 |
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者: 逆灵    时间: 2009-4-30 01:40

我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber4 b/ R7 ?2 O8 |7 u
和Name一样 就一定会被删除




欢迎光临 妖城在线论坛 (http://bbs.mocwww.com/) Powered by Discuz! 6.0.0