2

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したりなど、たくさんのことを試しました

4

0 に答える 0