10

次のように、暗号化/復号化に 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 関数はコールバック関数を受け入れません。

4

1 に答える 1