それらは同じ結果を生成するように見えますが、ノードdigest()
は Unicode 文字列を返しますが、Python はbytes
オブジェクトを返すため、これはすぐにはわかりません:
ノード 0.8.11 上の CoffeeScript 1.4.0:
coffee> salt='abc'
'abc'
coffee> password='def'
'def'
coffee> d = crypto.createHash('sha512').update(salt, 'binary').update(password, 'utf8').digest()
'ã.ñ#èí&ezK=\u0007»v\u0018\u0006CWEVNAP §\u0003¾*}¶\u001e=9\f+¹~-L1\u001fÜiÖ±&\u0005õ© ç'
Python 3.3.0:
>>> salt, password=b'abc', 'def'
>>> hash = hashlib.sha512()
>>> hash.update(salt)
>>> hash.update(password.encode('utf8'))
>>> d = hash.digest()
>>> print(d)
b'\xe3.\xf1\x96#\xe8\xed\x9d&\x7fez\x81\x94K=\x07\xad\xbbv\x85\x18\x06\x8e\x88CWEVN\x8dAP\xa0\xa7\x03\xbe*}\x88\xb6\x1e=9\x0c+\xb9~-L1\x1f\xdci\xd6\xb1&\x7f\x05\xf5\x9a\xa9 \xe7'
かなり違うように見えますよね?しかし、よく見ると、印刷可能な文字は同じです。そのCWEVN
実行は明らかです。また、これを Latin-1 としてデコードすると、さらに多くの類似点を見ることができます…</p>
>>> print(d.decode('latin1'))
ã.ñ#èí&ezK=»vCWEVNAP §¾*}¶=9
+¹~-L1ÜiÖ±&õ© ç
これがまったく同じ文字列であることは明らかです。Node が印刷できない文字をエスケープしているだけです。
そして Python 2.7.2:
>>> salt, password='abc', u'def'
>>> hash = hashlib.sha512()
>>> hash.update(salt)
>>> hash.update(password.encode('utf8'))
>>> d = hash.digest()
>>> print(d)
?.?#??&ez??K=??v???CWEVN?AP???*}??=9
+?~-L1?iֱ&? ?
>>> print(d.decode('latin1'))
ã.ñ#èí&ezK=»vCWEVNAP §¾*}¶=9
+¹~-L1ÜiÖ±&õ© ç
繰り返しますが、同じ文字列です。
私の端末、C ロケールなどはすべて UTF-8 (これは OS X) であるため、CoffeeScript が Latin-1 としてデコードされる理由がわかりません。