node.js реализация серверной части jCryption 3.0

Кто-нибудь реализовывал серверную часть плагина jCryption 3.0 с помощью node.js? Автор использует PHP для сервера, вот код на GitHub. Я борюсь с обработчиком рукопожатия, так или иначе я не могу расшифровать ключ base64 запроса с помощью моего личного ключа PEM (я использую модуль '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 padding был случай:

myPrivateKey.decrypt(base64key, 'base64', 'utf8', ursa.RSA_PKCS1_PADDING);

1 ответ

Решение

Вы пытались использовать другой Padding

RSA_PKCS1_PADDING вместо RSA_PKCS1_OAEP_PADDING

Как описано в документации

https://github.com/Obvious/ursa

Другие вопросы по тегам