node/test/parallel/test-crypto-padding-aes256.js

48 lines
1.6 KiB
JavaScript
Raw Normal View History

2012-09-11 21:40:39 +08:00
var common = require('../common');
var assert = require('assert');
if (!common.hasCrypto) {
console.log('1..0 # Skipped: missing crypto');
2012-09-11 21:40:39 +08:00
process.exit();
}
var crypto = require('crypto');
2012-09-11 21:40:39 +08:00
crypto.DEFAULT_ENCODING = 'buffer';
2012-09-11 21:40:39 +08:00
function aes256(decipherFinal) {
var iv = new Buffer('00000000000000000000000000000000', 'hex');
var key = new Buffer('0123456789abcdef0123456789abcdef' +
'0123456789abcdef0123456789abcdef', 'hex');
function encrypt(val, pad) {
var c = crypto.createCipheriv('aes256', key, iv);
c.setAutoPadding(pad);
return c.update(val, 'utf8', 'binary') + c.final('binary');
2012-09-11 21:40:39 +08:00
}
function decrypt(val, pad) {
var c = crypto.createDecipheriv('aes256', key, iv);
c.setAutoPadding(pad);
return c.update(val, 'binary', 'utf8') + c[decipherFinal]('utf8');
2012-09-11 21:40:39 +08:00
}
// echo 0123456789abcdef0123456789abcdef \
// | openssl enc -e -aes256 -nopad -K <key> -iv <iv> \
// | openssl enc -d -aes256 -nopad -K <key> -iv <iv>
var plaintext = '0123456789abcdef0123456789abcdef'; // multiple of block size
var encrypted = encrypt(plaintext, false);
var decrypted = decrypt(encrypted, false);
assert.equal(decrypted, plaintext);
// echo 0123456789abcdef0123456789abcde \
// | openssl enc -e -aes256 -K <key> -iv <iv> \
// | openssl enc -d -aes256 -K <key> -iv <iv>
plaintext = '0123456789abcdef0123456789abcde'; // not a multiple
encrypted = encrypt(plaintext, true);
decrypted = decrypt(encrypted, true);
assert.equal(decrypted, plaintext);
}
aes256('final');
aes256('finaltol');