标题:
[讨论]
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
[打印本页]
作者:
逆灵
时间:
2009-4-29 16:46
标题:
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
a) S! c; l- K7 @- z! L: M0 ]妖城在线论坛
bbs.mocwww.com) T4 P/ G6 [1 _, {4 W
相信现在很多人的数据库都会出现重名角色被替换的情况。
( s! y! y8 ?9 Z" J/ a5 \! Q魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
这种情况实际上是由数据库中的几个字段造成的,
" C3 C1 `. z& A5 F/ f. K2 l魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
首先我们来分析一下数据库表
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表. S3 Q$ ?1 R4 t) w
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート! T# [! w8 b5 @& i! b+ r
tbl_user 这个 是存放角色登入账号的。其中包括:
妖城在线论坛* B. b3 G7 \6 a2 m" Z8 M
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
7 p9 ]) |1 e. U1 M—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
1 r7 R, L8 e8 W6 ]( e
这里基本英文大家也明白了
妖城在线论坛) ^: O% B+ h8 j+ Z/ x2 P" q
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
+ L W9 q9 B, {! K魔力私服,最新魔力宝贝私服技术交流
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
; [# K y, j |; \8 E+ ^1 Ybbs.mocwww.com
这个字段直接影响到
魔力私服,最新魔力宝贝私服技术交流& [1 Y, l' S8 \" ^) C+ E- l
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表3 D) z9 N4 v( u
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
bbs.mocwww.com& C7 P& A, v* u3 S2 p
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
; j: k5 J5 j+ z—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
魔力私服,最新魔力宝贝私服技术交流& r1 O7 y B8 e& I, g4 `# c
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
! [5 O. `1 X/ }/ k6 j( ]3 S
! }8 }0 v" s) D3 f; g7 p—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
而
- P3 i$ H) ?/ X2 U. b7 [—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
: }1 {+ I1 }% `* p+ ^! f0 n! j. \
所以
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表4 L5 k4 C( l! Y# w9 M9 {
恢复人物的方法是。
# u* a$ S8 }" ~" ^8 W+ V—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
. e& }% Q+ O! d2 a魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
5 d1 O! p/ ~! ~: K" _$ C( T—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
这个RegistNumber 在tbl_skill的第二个字段也一样。
妖城在线论坛# O6 n& J, e. \1 j }( V( G! |
决定了该人物的技能
妖城在线论坛" v7 _$ ^& G8 [4 h4 J3 l
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
d& F/ ? C0 t) c. Z( B/ f魔力私服,最新魔力宝贝私服技术交流
; V6 X+ W* |; G; X妖城在线论坛
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表' [$ u* k4 E3 r$ S$ W
方法如下 打开注册网站的注册页
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート; z1 _4 u& E m/ v
找到这一行SQl语句:
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート- Q7 ^( q, x+ V, B" s
: H9 m% l# `/ Ibbs.mocwww.com
$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')";
; K8 |6 s$ z! X0 X3 I+ c
妖城在线论坛1 h8 }% j9 ]9 Q. j# r# I, A8 p
后字段的 '100'就是 创建人物序号
+ e, N; t0 q _/ f* z8 h9 C, O妖城在线论坛
自己更改即可造成重复也不会消失的人物。
魔力私服,最新魔力宝贝私服技术交流9 q' a: Q3 L* i/ r1 g0 b
魔力私服,最新魔力宝贝私服技术交流! L, U! }2 M( i
给高手们的建议:
8 c: r; w4 g' l! a4 |3 k! e5 U
由于本人的汇编很烂(我搞C++的)
魔力私服,最新魔力宝贝私服技术交流( [; |- g2 D& ?, h3 T- t2 g! K" Z, h
所以不想研究gmsv或者cg_190的 IDA反汇编编译。
妖城在线论坛/ o' N7 {, O, G6 H, Q8 j- v& T0 F" P0 d
: ?% A D8 V2 \4 q: N6 a& ]—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
懂这方面的朋友可以进行以下操作:
3 y. k; n: }5 Z/ }* a1 I
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート9 _# {, W' n& h- X: m F
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
* ~% W6 n- g/ ?" O妖城在线论坛
这样的话还是允许重名,但至少不会再删除。
* P/ f n" e3 p- n8 p: u—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
% s9 {* A l+ `; j; C+ ^& w妖城在线论坛
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
妖城在线论坛2 d- ^ C8 W) F5 K
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
) h4 J( _! x: k9 N* T! Z. [, }—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
希望能共享一下 谢谢。
作者:
黄昏
时间:
2009-4-29 19:08
嗯 之所以会删除是因为创建角色的语句为
魔力私服,最新魔力宝贝私服技术交流, i, [3 h3 s1 u- O+ @2 V+ U
REPLACE tbl_character VALUES……
bbs.mocwww.com$ H1 P; }, I9 [% Y& b7 l# L/ Y4 R
查mysql手册可知
- x% A a8 y: D ?* C魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
; P1 b5 z6 `4 W1 E3 i2 r( P7 G—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
嗯 解决方法论坛里面有人很早就发出来了…… 去掉name的索引就可以了……
- d0 m! U* e, O% d4 m* ?—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート) ^2 V" B& v4 p; ^8 L D, E3 S
不过这样不删除数据,但是还会有重名的角色存在
, _! L) z. G* g( E, ~4 z8 U% S
完善的解决方法可以从2方面考虑
: T3 `9 K) ?& t* D4 y$ t* Y: G( \& K魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
' x; d' b. z3 R2 l
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者:
逆灵
时间:
2009-4-30 01:40
我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
& j: I; }5 z; J9 a2 O1 C9 X魔力私服,最新魔力宝贝私服技术交流
和Name一样 就一定会被删除
欢迎光临 妖城在线论坛 (http://bbs.mocwww.com/)
Powered by Discuz! 6.0.0