首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >node.js实现jCryption 3.0服务器端部分

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

Stack Overflow用户
提问于 2013-12-12 12:14:45
回答 1查看 1.9K关注 0票数 0

有人用jCryption 3.0插件实现node.js的服务器端部分吗?作者使用PHP,下面是GitHub上的代码。我在与握手处理程序斗争,不知何故,我无法用我的私人base64密钥解密请求的密钥(我使用'ursa‘模块的RSA)。下面是我的处理程序(在挑战部分还没有完全完成):

代码语言:javascript
复制
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'})
     }
}

现在解密时总是会出错。如下所示:

代码语言:javascript
复制
Error: error:0407A079:rsa routines:RSA_padding_check_PKCS1_OAEP:oaep decoding error

你能看一下PHP工作流(上面的链接)并指出我做错了什么吗?谢谢

编辑:就像HazA说的填充是这样的:

代码语言:javascript
复制
myPrivateKey.decrypt(base64key, 'base64', 'utf8', ursa.RSA_PKCS1_PADDING);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-12-14 13:38:39

你试过用其他填充物吗?

RSA_PKCS1_PADDING而不是RSA_PKCS1_OAEP_PADDING

就像文档中描述的那样

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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20543273

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档