javascript (node.js) で暗号化されたデータ ブロックを生成し、HTTP 経由で別のシステムに渡そうとしています。結果を比較するために、php で参照システムが与えられました。
私の理解を超えているように見える理由により、JavaScript バージョンで PHP バージョンと同じ暗号化データを生成することができません。使用しているキーが同じであることを確認しました。私が間違っていることについて、これまでに何か手がかりやヒントを持っている人はいますか。
(はい、ECBが悪いことは知っていますが、それは私の選択ではありません)
リファレンス PHP 実装
<?php
function getEncrypt($str, $key)
{
$realKey = substr($key, 0, 16);
$padding = pkcs5_pad($str, 16);
return base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $realKey, $padding, MCRYPT_MODE_ECB));
}
function pkcs5_pad ($text, $blocksize)
{
$pad = $blocksize - (strlen($text) % $blocksize);
return $text . str_repeat(chr($pad), $pad);
}
$key = "oi3sgkosQPIdFa0eVSjecIhkha2nAfpn3anAozln0e9rkIGPvzUBgToCtlXLsKyjBITGKozHmn1NArgQodawidiVnyxccsf8ZnUgof4kq0iBCS7wrG1raytauMusRjjb";
$string = '{"pol.start":"11-06-2012 09:00:00","pol.end.after":43200,"lic.cache":"yes","playback":2880,"out.digital":"use","out.analog":"use"}';
$encData = getEncrypt($string, $key);
var_dump($encData);
私のJavascriptの試み:
var crypto = require('crypto');
var cipherAlgo = 'AES-128-ECB';
var policy = '{"pol.start":"11-06-2012 09:00:00","pol.end.after":43200,"lic.cache":"yes","playback":2880,"out.digital":"use","out.analog":"use"}';
var sharedSecret = 'oi3sgkosQPIdFa0eVSjecIhkha2nAfpn3anAozln0e9rkIGPvzUBgToCtlXLsKyjBITGKozHmn1NArgQodawidiVnyxccsf8ZnUgof4kq0iBCS7wrG1raytauMusRjjb';
var util = require('util');
function encrypt(string, key)
{
var realKey = key.substring(0,16);
var cipher = crypto.createCipher(cipherAlgo, key.substring(0,16));
//encrypt our string
var encrypted = cipher.update(string, 'utf8', 'base64');
encrypted += cipher.final('base64');
return encrypted;
}
console.log(encrypt(policy, sharedSecret));
出力をバイナリにリジギングしたり、バッファに入れたり、base64ingしたりなど、たくさんのことを試しました
。