我最近为我的游戏社区获得了 IPBoard 板软件,我从 SMF 转换了它。
当我使用 smf 时,我使用了一个系统来授权玩家在我的游戏服务器中注册,这个脚本称为 php 脚本,它对玩家在游戏中输入的密码进行哈希 (sha1) 并将其发送回运行的脚本游戏。然后我在让他玩之前检查了玩家是否在论坛中注册。好吧,IPBoard 使用不同的哈希:
$hash = md5( md5( $salt ) . md5( $password ) );
在哪里:
$hash is the value stored in the database column members_pass_hash.
$salt is the value stored in the database column members_pass_salt.
$password is the plaintext password.
我正在尝试制作一个 php 脚本,该脚本将返回游戏中的脚本正确的哈希值,稍后我会将其从游戏中比较到数据库中。这是我的代码:
<?php
include("mta_sdk.php");
$input = mta::getInput();
// Configuración de la aplicación
$DB_SERVIDOR = 'localhost:3306';
$DB_USUARIO = 'root';
$DB_CLAVE = 'xxx';
$DB_BASEDATOS = 'ipboard';
$conexion = mysql_connect($DB_SERVIDOR, $DB_USUARIO, $DB_CLAVE);
mysql_select_db($DB_BASEDATOS, $conexion);
mysql_query("SET NAMES 'utf8'");
$sql = "SELECT members_pass_salt FROM ipb_members WHERE name = '".$input[2]."'";
$Res = mysql_query($sql, $conexion);
$rowRes = mysql_fetch_assoc($Res);
$salt = $rowRes['members_pass_salt']
$hash = md5( md5( $salt ) . md5( $input[3] ) );
//$hash = $salt;
// Return encrypted string using MD5
mta::doReturn($hash,$input[1],$input[2],$input[3],$input[4]);
?>
$input 变量返回尝试玩游戏的用户给出的信息。它是一个数组,如下所示:
$input[2] - the username;
$input[3] - the password (plain text)
其他值是游戏正在使用的东西,不需要。
我成功地从游戏中调用了 php 脚本,并且 php 正在发回信息,但它返回的哈希是:“错误”
我尝试了许多不同的方法,但总是得到相同的错误消息而不是哈希。
一些可能有趣的额外信息:
我正在谈论的游戏是 Multi Theft Auto,它是对 GTA:SA 的多人游戏修改(也许有人知道),它使用 LUA 作为脚本。
mta_sdk.php 文件是为此游戏开发的 php sdk(能够使用外部 php 脚本从游戏中发送和接收信息。
也许这不是一个传统的问题。我试图尽可能地解释这一点,因为我知道你不会习惯这个游戏以及它是如何工作的。
提前致谢