doz22551 2012-08-10 16:06
浏览 111

Node.JS和PHP AES-128-EBC数据加密

I'm trying to generate an encrypted block of data in javascript (node.js), and then pass to another system via HTTP. I've been given a reference system in php to compare my results with.

For reasons that are seemingly beyond my grasp I cannot get my javascript version to produce the same encrypted data as the PHP version. I've checked that the keys I'm using are the same. Does anyone have any clues or tips what so ever on what I'm doing wrong.

(Yes I know the ECB is bad, but it's not my choice)

Reference PHP implementation

<?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);

My Javascript attempt:

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));

I have tried lots of things like rejigging output to binary, putting into a buffer and base64ing that etc etc.
For the love of my sanity can someone help on this.

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 素材场景中光线烘焙后灯光失效
    • ¥15 请教一下各位,为什么我这个没有实现模拟点击
    • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
    • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
    • ¥20 有关区间dp的问题求解
    • ¥15 多电路系统共用电源的串扰问题
    • ¥15 slam rangenet++配置
    • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
    • ¥15 ubuntu子系统密码忘记
    • ¥15 保护模式-系统加载-段寄存器