jCryption 3.0 プラグインのサーバー側部分を node.js で実装した人はいますか? 著者はサーバーに PHP を使用しています。コードは GitHub にあります。ハンドシェイクハンドラーに苦労しています。どういうわけか、プライベートPEMキーでリクエストのbase64キーを復号化できません(RSAには「ursa」モジュールを使用しています)。これが私のハンドラーです(チャレンジ部分で完全には終了していません):
var ursa = require('ursa');
...
// write public key to HTML with EJS
exports.getPublicKeyMiddleware = function(req, res, next){
res.publicKey = req.app.get('publicKey'); // stores result of readFile(PUBLIC_KEY.PEM)
next();
};
exports.handshake = function(req, res, next) {
var base64key = req.body.key;
var privateKey;
var challenge;
if (!!base64key) {
myPrivateKey = ursa.createPrivateKey(req.app.get('privateKey'));
try {
challenge = privateKey.decrypt(base64key, 'base64', 'utf8');
res.json({challenge: challenge});
}
catch (e) {
res.json({error: 'Error decoding key'});
console.log(e.message);
}
}
else {
res.json({error: 'No key in request'})
}
}
これで、復号化時に常にエラーになります。このような:
Error: error:0407A079:rsa routines:RSA_padding_check_PKCS1_OAEP:oaep decoding error
PHPワークフロー(上記のリンク)を見て、私が間違っていることを教えてください。ありがとう
編集: HazAが言ったように、パディングは事実でした:
myPrivateKey.decrypt(base64key, 'base64', 'utf8', ursa.RSA_PKCS1_PADDING);