我有一个lua脚本,它对字符串进行加密,并通过http将其发送到PHP脚本。问题是,加密过程使用Lua的math.randomseed和math.random。当尝试在PHP中解密字符串时,mt_srand和mt_rand产生的数字与Lua不同。
怎样才能让php生成像Lua这样的数字呢?
--编辑
好的,在我的(非常简单的)加密中,我使用一个密钥来生成一个种子。这个种子让我每次都能得到相同的“随机数”。
因此,如果我的密钥产生一个种子,比如说80,并且我在Lua中使用这个...
math.randomseed(80)
local randomNumber = math.random(1, 20)
// randomNumber = 3当尝试在PHP中解密时,我将使用相同的种子,但得到不同的输出。
mt_srand(80);
$randomNumber = mt_rand(1, 20);
// $randomNumber = 10我需要找出一种方法来取回相同的数字,这样我才能解密字符串。
发布于 2013-11-15 01:48:08
而不是试图通过为相反的语言复制Lua或PHP中的现有随机函数来重新发明轮子。我发现使用下面链接中的方法要容易得多。只需将代码移植到Lua,一切都很顺利。显然,它不会适合每个人的情况,但对于我如何使用它,它是完美和简单的。http://www.sitepoint.com/php-random-number-generator/
class Random {
// random seed
private static $RSeed = 0;
// set seed
public static function seed($s = 0) {
self::$RSeed = abs(intval($s)) % 9999999 + 1;
self::num();
}
// generate random number
public static function num($min = 0, $max = 9999999) {
if (self::$RSeed == 0) self::seed(mt_rand());
self::$RSeed = (self::$RSeed * 125) % 2796203;
return self::$RSeed % ($max - $min + 1) + $min;
}
}我只更改了默认种子,并使用mt_rand()删除了该行
然后在Lua中,我创建了以下代码:
local mySeed = 0;
function setSeed(s)
mySeed = math.abs(tonumber(s)) % 9999999 + 1;
myRand();
end
function myRand(min, max)
min = min or 0;
max = max or 9999999;
mySeed = (mySeed * 125) % 2796203;
return mySeed % (max - min + 1) + min;
end发布于 2013-11-15 01:09:54
你需要一个随机数生成器,它在php和lua上使用相同的算法。
你要么为Lua找到一个随机数生成器,要么为PHP找到一个具有相同实现的随机数生成器,或者你必须自己编写一个。此外,使用系统内部生成器也很糟糕,因为它们可能每次都会更改,然后您的脚本也不再有效。
https://stackoverflow.com/questions/19982405
复制相似问题