DP-S_Script/MyProject/DPS登录器.nut

168 lines
5.9 KiB
Plaintext

class _DPS_Login_Gateway_ {
//数据库连接
MysqlObject = null;
PackHandleMap = null;
constructor() {
PackHandleMap = {};
MysqlObject = Mysql(Str_Ptr("127.0.0.1"), 3306, Str_Ptr("taiwan_cain"), Str_Ptr("game"), Str_Ptr("uu5!^%jg"));
MysqlObject.Exec_Sql(format("SET NAMES %s", "latin1"));
//创建一个Http Server
try {
local HS = HttpServer("0.0.0.0", "41817");
HS.Listen(function(SocketObject, Header, Msg) {
getroottable()._DPS_Login_Gateway_Object_._HttpServer_Event_DPS_(SocketObject, Header, Msg);
});
} catch (exception) {
}
PackHandleMap["/GetConfig"] <- function(SocketObject, Header, Jso) {
local Config = sq_ReadJsonFile("/dp_s/OfficialConfig/登录器配置.json");
//读取DPS登录器的配置并发送
SocketObject.Write(Config);
}
PackHandleMap["/Login"] <- function(SocketObject, Header, Jso) {
if (!Jso.rawin("account")) return;
if (!Jso.rawin("passwd")) return;
local account = Jso.account;
local passwd = Jso.passwd;
local passwd_hash = MD5_Hash(passwd);
//正则表达式 只允许字母和数字
local regex = regexp("^[A-Za-z0-9]{1,19}$");
if (!regex.match(account)) {
SocketObject.Write({
error = "账号只能包含字母和数字且长度小于20"
});
return;
}
local sql = format("select UID from d_taiwan.accounts where accountname='%s' and password='%s';", account, passwd_hash);
local Ret = MysqlObject.Select(sql, ["int"]);
if (Ret && Ret.len() > 0) {
local Uid = Ret[0][0];
local str = format("%08x010101010101010101010101010101010101010101010101010101010101010155914510010403030101", Uid);
local Byte = Sq_Rsa_Private_Encrypt(str);
local EnStr = MD5.base64_encode(Byte);
//发送登录Token
SocketObject.Write({
token = EnStr
});
} else {
SocketObject.Write({
error = "账号或密码错误!"
});
}
}.bindenv(this);
PackHandleMap["/Register"] <- function(SocketObject, Header, Jso) {
if (!Jso.rawin("account")) return;
if (!Jso.rawin("passwd")) return;
local account = Jso.account;
local passwd = Jso.passwd;
//正则表达式 只允许字母和数字
local regex = regexp("^[A-Za-z0-9]{1,19}$");
if (account.len() == 0 || !regex.match(account)) {
SocketObject.Write({
error = "账号只能包含字母和数字且长度大于0小于20"
});
return;
}
if (passwd.len() == 0 || !regex.match(passwd)) {
SocketObject.Write({
error = "密码只能包含字母和数字且长度大于0小于20"
});
return;
}
if (GetAccountByName(account) != null) {
SocketObject.Write({
error = "账号已存在"
})
return;
}
local passwd_hash = MD5_Hash(passwd);
local sql = format("INSERT INTO d_taiwan.accounts(accountname, password)VALUES( '%s' , '%s');", account, passwd_hash);
MysqlObject.Exec_Sql(sql);
local Ret = MysqlObject.Select("SELECT LAST_INSERT_ID()", ["int"]);
if (Ret && Ret.len() > 0) {
local Uid = Ret[0][0].tostring();
MysqlObject.Exec_Sql(format("INSERT INTO d_taiwan.member_info(m_id, user_id)VALUES('%s','%s');", Uid, Uid));
MysqlObject.Exec_Sql(format("INSERT INTO d_taiwan.member_white_account(m_id)VALUES('%s')", Uid));
MysqlObject.Exec_Sql(format("INSERT INTO taiwan_login.member_login(m_id)VALUES('%s')", Uid));
MysqlObject.Exec_Sql(format("INSERT INTO taiwan_billing.cash_cera(account, cera,mod_tran,mod_date, reg_date)VALUES('%s',0,0,NOW(), NOW())", Uid));
MysqlObject.Exec_Sql(format("INSERT INTO taiwan_billing.cash_cera_point(account, cera_point,mod_date, reg_date)VALUES('%s',0,NOW(), NOW())", Uid));
SocketObject.Write({
success = "账号注册成功,现在您可以登录了!"
});
return;
}
}.bindenv(this);
}
function GetAccountByName(account) {
local sql = format("select UID , accountname, password from d_taiwan.accounts where accountname='%s'", account);
local Ret = MysqlObject.Select(sql, ["int", "string", "string"]);
print(Ret);
if (!Ret || Ret.len() == 0) {
return null;
}
return {
uid = Ret[0][0],
account = Ret[0][1],
passwd = Ret[0][2]
}
}
function _HttpServer_Event_DPS_(SocketObject, Header, Msg) {
if (PackHandleMap.rawin(Header.path)) {
local Jso = null;
try {
Jso = Json.Decode(Msg);
} catch (exception) {
}
if (!Jso) return;
PackHandleMap[Header.path](SocketObject, Header, Jso);
} else {
SocketObject.Write({
error = "error url"
});
}
}
function MD5_Hash(str) {
local Ctx = Memory.alloc(0x100);
MD5.MD5_Init(Ctx.C_Object);
MD5.MD5_Update(Ctx.C_Object, Memory.allocUtf8String(str).C_Object, str.len());
local Result = Memory.alloc(16);
MD5.MD5_Final(Result.C_Object, Ctx.C_Object);
return MD5.hex_encode(Result.readUtf8String(16));
}
}
Timer.SetTimeOut(function() {
getroottable()._DPS_Login_Gateway_Object_ <- _DPS_Login_Gateway_();
}, 1);