我工作的一个传统的ColdFusion MX7现场。 他们希望实现“咸鱼哈希”密码系统。 但一段时间后,在未来一年左右的时间,他们计划建立一个全新的PHP的网站,不希望有复位(输)所有的密码。
于是我找了一些代码,将两个平台上工作。
我是新来的这一点,但据我所知道的,下面的代码两大块应该做同样的事情。 然而,他们产生不同的结果。 任何人都关心帮助?
ColdFusion代码:
<cffunction name="computeHash" access="public" returntype="String">
<cfargument name="password" type="string" />
<cfargument name="salt" type="string" />
<cfargument name="iterations" type="numeric" required="false" default="1024" />
<cfargument name="algorithm" type="string" required="false" default="SHA-1" />
<cfscript>
var hashed = '';
hashed = hash( password & salt, arguments.algorithm, 'UTF-8' );
</cfscript>
<cfloop from="1" to="#iterations#" index="i">
<cfscript>
hashed = hash( hashed & salt, arguments.algorithm, 'UTF-8' );
</cfscript>
</cfloop>
</cffunction>
PHP代码:
function computeHash($password,$salt)
{
$hashed = '';
$hashed = hash('sha1', $password . $salt);
for ($i = 1; $i <= 1024; $i++)
{
$hashed = hash('sha1', $hashed . $salt);
}
echo $hashed;
}
更新1:谢谢您的答复! 使用的“P @ ssW0rd”密码,和“JjXSROiYyKkxNzTklaiErQ ==”生成以下结果的盐:
COLDFUSION:
代码,第1部分:
hashed = hash( password & salt, arguments.algorithm, 'UTF-8' );
产生:
A0A8DE3A3B2A8BFD74766EEE126950F4462D3BCB
代码,第2部分:
hash( hashed & salt, arguments.algorithm, 'UTF-8' );
产生:
CFF9B75918B75761B5568854782CD709B2941637
PHP:
代码,第1部分:
$hashed = hash('sha1', $password . $salt);
产生:
a0a8de3a3b2a8bfd74766eee126950f4462d3bcb
代码,第2部分:
hash('sha1', $hashed . $salt);
产生:
e955404423747ec706561fa9a319ddac47194a65
正如你所看到的,第一次,输出相匹配。 但是,当我重新哈希,他们不再匹配。 我糊涂了。