次のように、暗号化/復号化に Node.js の Crypto ライブラリを使用しています。
encrypt = function(text, passPhrase){
var cipher = crypto.createCipher('AES-128-CBC-HMAC-SHA1', passPhrase);
var crypted = cipher.update(text,'utf8','hex');
crypted += cipher.final('hex');
return crypted;
} ,
decrypt = function(text, passPhrase){
var decipher = crypto.createDecipher('AES-128-CBC-HMAC-SHA1', passPhrase)
var dec = decipher.update(text,'hex','utf8')
dec += decipher.final('utf8');
return dec;
}
暗号化部分は問題ありません。また、復号化のために正しいパスフレーズを送信しても問題はありません。私の問題は、復号化のために「間違った」パスフレーズを送信すると、コードが壊れてエラーがスローされることです。
TypeError: Bad input string
at Decipher.Cipher.update (crypto.js:279:27)
at module.exports.decrypt (/xxxx/yyyyy/jjj/ssss/encryptionService.js:19:28)
at Object.module.exports.passwordDecryptor (/xxxx/yyyyy/jjj/ssss/encryptionService.js:59:56)
at Object.<anonymous> (/xxxx/yyyyy/jjj/ssss/test.js:32:33)
at Module._compile (module.js:456:26)
at Object.Module._extensions..js (module.js:474:10)
at Module.load (module.js:356:32)
at Function.Module._load (module.js:312:12)
at Function.Module.runMain (module.js:497:10)
at startup (node.js:119:16)
私はそれが起こりたくない。たとえば、復号化関数が「パスフレーズが間違っています」という文を返します。ドキュメントによると、ここにリンクの説明を入力してください createDecipher 関数はコールバック関数を受け入れません。