簡體   English   中英

jCryption 3.0服務器端部分的node.js實現

[英]node.js implementation of jCryption 3.0 server-side part

有沒有人用node.js實現jCryption 3.0插件的服務器端部分? 作者將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);

您是否嘗試過使用其他填充

RSA_PKCS1_PADDING代替RSA_PKCS1_OAEP_PADDING

如文檔中所述

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM