不同的河豚加密结果

时间:2017-08-30 08:15:36

标签: javascript encryption blowfish

我正在尝试将特定功能从SAP系统复制到网站,并且流程的一部分是河豚加密。我四处寻找Javascript的Blowfish加密库,并将其实现到我的js代码中。

但是,与原始SAP流量相比,我们的河豚加密结果不同。

唯一不同的是SAP blowfish使用UTF-16LE。我已经尝试将我的密码和文本转换为UTF-16LE,但我无法从原始系统获得相同的结果。

我在搜索时发现了这两个代码(这两个转换/解码来自UTF8-UTF16,反之亦然)

function strEncodeUTF16(str) {
  var byteArray = new Uint8Array(str.length * 2);
    for (var i = 0; i < str.length; i++) {
    byteArray[i*2] = str.charCodeAt(i); // & 0xff;
    byteArray[i*2+1] = str.charCodeAt(i) >> 8; // & 0xff;
    }
    return String.fromCharCode.apply(String,byteArray);
}

function decodeUTF16LE( binaryStr ) {
    var cp = [];
    for( var i = 0; i < binaryStr.length; i+=2) {
        cp.push( 
             binaryStr.charCodeAt(i) |
            ( binaryStr.charCodeAt(i+1) << 8 )
        );
    }

    return String.fromCharCode.apply( String, cp );
}

我正在使用的blowfish库来自Dojo Toolkit: Blowfish.js from Dojo Toolkit 1.8.1

示例测试用例是:

密码:7F30742A2

文字:329

结果: B33663DFAC049492

然而,当我在我的最后尝试时

var encrypted = blowfish.encrypt(id, key, {outputType:1, cipherMode: 0});

我的结果是: ef701b0e904b10c3

我不确定这种差异发生在哪里。有什么想法吗?

0 个答案:

没有答案