node.js实现jCryption 3.0服务器端部分

时间:2013-12-12 12:14:45

标签: php node.js encryption rsa jcryption

是否有人使用node.js实现jCryption 3.0 plugin的服务器端部分?作者使用PHP作为服务器here's code on GitHub。我正在努力解决握手处理程序,不知何故我无法使用我的私有PEM密钥解密请求的base64密钥(我使用'ursa'模块进行RSA)。这是我的处理程序(它在挑战部分没有完全完成):

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

1 个答案:

答案 0 :(得分:1)

您是否尝试使用其他Padding

RSA_PKCS1_PADDING代替RSA_PKCS1_OAEP_PADDING

如文档中所述

https://github.com/Obvious/ursa#decryptbuf-bufencoding-outencoding-padding