レガシー ColdFusion MX7 サイトで作業しています。彼らは「塩漬けハッシュ」パスワードシステムを実装したいと考えています。しかし、来年かそこらで完全に新しい PHP サイトを構築する予定であり、すべてのパスワードをリセット (紛失) する必要はありません。
そのため、両方のプラットフォームで動作するコードを探しています。
私はこれに慣れていませんが、私が知る限り、次の 2 つのコード ブロックは同じことを行うはずです。ただし、それらは異なる結果を生成します。誰か助けてくれませんか?
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==」のソルトを使用すると、次の結果が生成されます。
コールドフュージョン:
コード、パート 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
ご覧のとおり、最初は出力が一致しています。しかし、再ハッシュすると、それらは一致しなくなります。よくわかりません。