node-rsa解密不起作用

问题描述 投票:1回答:1

我试图实施rsa公钥系统。该服务器是使用node-js实现的,并使用node-rsa库对rsa进行加密/解密。

并且该客户端是使用Java实现的。

在身份验证部分,客户端(java)使用服务器的公钥对客户端的标识和密码进行加密,并使用http post发布到服务器。

所以服务器可以完美地接收它们,但是在node-rsa解密功能中,什么也没有发生,并且HTTP请求被拒绝500

下面的客户代码

public static boolean REQ_AUTH(String user_id, String user_pw )
{
    InputStreamReader ret = null;
    try
    {
        JSONObject obj = new JSONObject();
        obj.put("user_id", "waps12b");
        obj.put("user_pw", "password");

        String cipher = VoteUtility.EncryptRSA(obj.toString());
        ret = PostHTTP(API_URL.AUTH, "cipher=" + cipher);
        JSONParser parser = new JSONParser();
        JSONObject json = (JSONObject)parser.parse(ret);
        ret.close();


        String result = (String)json.get(JSON_KEY.Result);
        if(result.equals("FALSE"))
            return false;

        VoteUtility.Setting((String)json.get(JSON_KEY.Kp));
        RN = (String)json.get(JSON_KEY.RN);
        return true;
    }catch(Exception ex)
    {
        ex.printStackTrace();
    }
    return false;
}

下面的服务器代码

router.all('/auth', function(req, res){
    var cipher = req.body.cipher;
    console.log('[cipher] : ' + cipher);

    var buf = new Buffer(cipher,'hex');
    console.log('[buf] : ' + buf.toString('hex'));

    var decrypted = key.decrypt(buf);
    console.log('[plain] : ' + decrypted);
}

和下面的服务器日志

[cipher] : 46641844ffffff8d18ffffffb6ffffff8d6fffffffcf37ffffffd3ffffffa520721407ffffffbf7810ffffffc87d7925ffffffae16ffffffc9620f356872ffffff892828ffffffb533ffffffb324ffffffffffffffeefffffffa6b78ffffff8effffffb1ffffffb3ffffffdd681affffffae405d105affffff9626ffffff85fffffff8ffffffc9fffffff22c69ffffffa87efffffff8ffffffe64e082fffffffd247500f176dffffffedffffffcc6c5affffffc712ffffff9136ffffffbe26672b206cffffffa56dffffffa4ffffff85ffffffc0ffffffff0b6936fffffffb61ffffff8a0f3effffff8effffff965d5851ffffffaeffffff9dffffffb1417c57ffffffbfffffffee5affffff80ffffff9bffffffac0bffffff9cffffffaf6377327d
[buf] : 46641844ffffff8d18ffffffb6ffffff8d6fffffffcf37ffffffd3ffffffa520721407ffffffbf7810ffffffc87d7925ffffffae16ffffffc9620f356872ffffff892828ffffffb533ffffffb324ffffffffffffffeefffffffa6b78ffffff8effffffb1ffffffb3ffffffdd681affffffae405d105affffff9626ffffff85fffffff8ffffffc9fffffff22c69ffffffa87efffffff8ffffffe64e082fffffffd247500f176dffffffedffffffcc6c5affffffc712ffffff9136ffffffbe26672b206cffffffa56dffffffa4ffffff85ffffffc0ffffffff0b6936fffffffb61ffffff8a0f3effffff8effffff965d5851ffffffaeffffff9dffffffb1417c57ffffffbfffffffee5affffff80ffffff9bffffffac0bffffff9cffffffaf6377327d
POST /api/auth 500 421.025 ms - 1158    

我该如何解决?

java javascript node.js encryption rsa
1个回答
0
投票

在节点js中尝试

const NodeRSA   = require('node-rsa');
const key       = new NodeRSA('-----BEGIN RSA PRIVATE KEY-----PRIVATE_key----- 
END RSA PRIVATE KEY-----");
const text = 'helo or array';
const encrypted = key.encrypt(text, 'base64');
console.log('encrypted: ', encrypted);
© www.soinside.com 2019 - 2024. All rights reserved.