标题:
[讨论]
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
[打印本页]
作者:
逆灵
时间:
2009-4-29 16:46
标题:
【数据库重名】问题的研究结果,及【粗略解决方法】希望有人能完善下。
PS:没有耐心的 和对数据库完全不通的,以及对这方面不感兴趣的请pass。我自己都觉得头晕~~~~~~~~~~
3 B; z* c$ B, i0 M" V5 ?1 z8 b7 y! J- v
^3 C' P9 n6 H( v' ^( E, b m妖城在线论坛
相信现在很多人的数据库都会出现重名角色被替换的情况。
. h: m: @% M" g; Q/ F4 Gbbs.mocwww.com
这种情况实际上是由数据库中的几个字段造成的,
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表8 K% F4 \' m. Z+ y$ W
首先我们来分析一下数据库表
) R; Y- P6 |/ j& q/ R魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
1 V- l- o* ?0 E, D+ z魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
tbl_user 这个 是存放角色登入账号的。其中包括:
) F9 p- r- E, d) t' t3 d, B! M( L! V
AccountID AccountPassword EnableFlg TrialFlg DownFlg ExpFlg SequencNumber UseFlg BadMsg CdKey ID RegTime ip safeword HellScore
魔力私服,最新魔力宝贝私服技术交流5 P- t7 l- v- {
1 m' y0 @4 |; U. o; R; F2 Y( Y魔力私服,最新魔力宝贝私服技术交流
这里基本英文大家也明白了
魔力私服,最新魔力宝贝私服技术交流6 a7 W9 X% I, x( _% T
EnableFlg 这个就是决定账号是否冻结的 另外 这里影响到重名删号问题的字段是
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1 E% f& p* d% c4 K' `. t+ J
SequencNumber 这个字段就是代表你该账号开角色的序列号。每建立一个角色 该字段自动+1 删除角色不减
! z: z" p5 L3 O魔力私服,最新魔力宝贝私服技术交流
这个字段直接影响到
% ?* [, ^6 g# D* }魔力私服,最新魔力宝贝私服技术交流
tbl_character 即人物表 的第49列数据 即 RegistNumber,就是 人物注册序列号
& y! r( L" }3 H妖城在线论坛
实际上这里才是关键,当建立人物的名字和该字段的序列号完全相同时,系统将会自动将数据Update【更新】而不是Insert【插入】
妖城在线论坛5 [8 b! W! E1 t! r- ]
就好像说你登出 要存档,这个存档就会替换原来那个存档 这种方式
8 x/ Y* H/ I- S/ [妖城在线论坛
bbs.mocwww.com: N: h, c1 i1 b' s% L
即后面建立的人物替换了该行人物的资料。当然 CDKey也被替换,所以 前一个账号的CDKey中 即账号中 人物就消失了。
9 }1 {, ~5 ~6 ^5 `8 C魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
& r; n7 N# R' E魔力私服,最新魔力宝贝私服技术交流
而
+ A( e7 D; d( D$ C+ a0 J9 \* L Y" k魔力私服,最新魔力宝贝私服技术交流
tbl_item 的第91个字段 RegistNumber 决定了 人物物品的位置,以及tbl_skill 中的字段并未被替换消失。
9 C, z' ^# }- T$ u5 q魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
所以
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート) @5 O* \8 Z6 F5 Y# v
恢复人物的方法是。
" ^# C+ _% ~/ t( }0 u魔力私服,最新魔力宝贝私服技术交流
在被替换的账号中,建立角色名和原来完全相同的角色,并且把tbl_character 中的 RegistNumber 改回和
5 |4 F. U& f' F魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
tbl_item 中的 该账号原来角色的 RegistNumber 相同 即可
2 r: E- A% J, H. d1 ybbs.mocwww.com
这个RegistNumber 在tbl_skill的第二个字段也一样。
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート2 y, o! F+ F6 P# E
决定了该人物的技能
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表1 L, F5 y0 p) V7 e* h( {1 n# ?5 y
那么 原来的人物的技能和物品都将会被回复~~~~~~~~~~~~~~~~~~
魔力私服,最新魔力宝贝私服技术交流8 {# X6 _; Q" F# W6 r* E3 l
( n% B/ ~5 \* f—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
小建议。 相隔一段时间 更改一下 注册的页面的SQL语句代码~ 使得注册的SequenceNumber不一样就行了
bbs.mocwww.com; c1 {, }" ]) W! j6 R* ]/ q
方法如下 打开注册网站的注册页
魔力私服,最新魔力宝贝私服技术交流; I! c2 p+ x7 j7 P9 m2 U4 a, S9 [
找到这一行SQl语句:
: a/ l2 |6 B8 B3 |3 K1 s' t* g魔力私服,最新魔力宝贝私服技术交流
妖城在线论坛! d0 O/ ]: C, O, K
$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')";
+ E7 p* G: R/ r妖城在线论坛
8 J/ Q. P6 N; o( Z1 z# L3 ~
后字段的 '100'就是 创建人物序号
9 D" P9 A# k% T& ~ e4 Y7 I
自己更改即可造成重复也不会消失的人物。
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート. X. d/ Y- v& x+ R
# }: @* B6 E9 A* A# a# r魔力私服,最新魔力宝贝私服技术交流
给高手们的建议:
bbs.mocwww.com. p3 k! R3 Z6 X: J
由于本人的汇编很烂(我搞C++的)
# k" j! Y) { L R- T3 Dbbs.mocwww.com
所以不想研究gmsv或者cg_190的 IDA反汇编编译。
魔力私服,最新魔力宝贝私服技术交流5 a3 w& ?6 ^' d. W# t0 B2 `% k
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表, S% H6 B# T; i$ q0 U) V$ a/ C
懂这方面的朋友可以进行以下操作:
. ]4 U( o$ c% H1 rbbs.mocwww.com
1加入验证组。进行character表的Name行字段验证,如有重名的返回错误不让创建人物即可,这个 貌似同一个账号创建相同名字的人物时会提示,调用即可。
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート! U" s1 Q8 k' y8 u% ~; f' g0 y
2更改更新人物时候的SQL语句,不是进行Name 和 RegistNumber 的判断, 改为 CDKEY和 RegistNumber的判断
bbs.mocwww.com6 _9 w5 {5 M: B5 {. N) o$ v) z1 J7 h
这样的话还是允许重名,但至少不会再删除。
) F3 [" L; ]; ~* r% T, t9 [: }+ a6 H—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
! Q! d8 c! E& Y) w) d—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート
PS:另外听说过某些人可以通过网站验证重名,之类的。。。。。。
- o, U5 `; ?, r8 K! j妖城在线论坛
我暂时是没时间搞这么多了,这里只写给觉得有用的人看看,如果有用 ,写出了不允许建立重名账号的
6 ~1 r) _4 l l1 @魔力私服,最新魔力宝贝私服技术交流
希望能共享一下 谢谢。
作者:
黄昏
时间:
2009-4-29 19:08
嗯 之所以会删除是因为创建角色的语句为
, o* G. X/ D* G. G6 ]2 y4 z9 Y( S魔力私服,最新魔力宝贝私服技术交流
REPLACE tbl_character VALUES……
妖城在线论坛( M" _ [6 D) t$ }
查mysql手册可知
—魔力私服,魔力宝贝私服技术,DELPHI编程,魔力寶貝, 魔力宝贝, 크로스게이트,クロスゲート: ]0 o& c. @, T$ d; r5 a1 q/ K
REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
妖城在线论坛" n5 |4 H8 N' b( T
嗯 解决方法论坛里面有人很早就发出来了…… 去掉name的索引就可以了……
$ ^+ |0 e0 F* i魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表
魔力私服,最新魔力宝贝私服技术交流/ G& K/ a4 J9 y+ Y/ [0 ?+ V; P
不过这样不删除数据,但是还会有重名的角色存在
魔力私服,最新魔力私服,魔力宝贝私服,魔力宝贝私服技术,魔力宝贝私服,私服架设技术,妖城,FLASH,电影,黑客,网络,网吧,破解,入侵,注册表/ T& ^* n5 `8 K! R& z* U& h
完善的解决方法可以从2方面考虑
8 B+ @$ l7 ]7 E+ R2 W
gmsv方面,汇编添加语句判断(流传一种比较类似的解决重名办法,但是会导致停端时玩家数据保存失败,等待完善中……)
. o& {+ }/ u: |' a( n0 s1 z) z, O! M
cg方面就是hook 创建角色的函数并结合php来判断是否能成功创建角色了,可能被绕过,不是很完美……
作者:
逆灵
时间:
2009-4-30 01:40
我验证过 增加索引和 去掉索引都是一样的 只要RegistNumber
2 c5 T: A& A. fbbs.mocwww.com
和Name一样 就一定会被删除
欢迎光临 妖城在线论坛 (http://bbs.mocwww.com/)
Powered by Discuz! 6.0.0